-
bitcoin $87959.907984 USD
1.34% -
ethereum $2920.497338 USD
3.04% -
tether $0.999775 USD
0.00% -
xrp $2.237324 USD
8.12% -
bnb $860.243768 USD
0.90% -
solana $138.089498 USD
5.43% -
usd-coin $0.999807 USD
0.01% -
tron $0.272801 USD
-1.53% -
dogecoin $0.150904 USD
2.96% -
cardano $0.421635 USD
1.97% -
hyperliquid $32.152445 USD
2.23% -
bitcoin-cash $533.301069 USD
-1.94% -
chainlink $12.953417 USD
2.68% -
unus-sed-leo $9.535951 USD
0.73% -
zcash $521.483386 USD
-2.87%
Quelle est la différence entre Msg.Sender et Tx.origin?
In Ethereum smart contracts, `msg.sender` identifies the immediate caller, while `tx.origin` traces back to the original transaction initiator, each serving distinct security and logic purposes.
Jul 23, 2025 at 06:28 pm
Comprendre les bases de l'exécution du contrat intelligent Ethereum
Dans la blockchain Ethereum , les contrats intelligents interagissent avec les utilisateurs et autres contrats via des transactions et des appels de fonction. Lors du développement ou de l'analyse des contrats intelligents à l'aide de Solidity , il est essentiel de comprendre la différence entre Msg.Sender et Tx.origin . Les deux sont des variables globales utilisées pour récupérer les informations d'adresse pendant l'exécution du contrat, mais elles servent des objectifs distincts et se comportent différemment dans divers contextes.
MSG.Sender fait référence à l'appelant immédiat de la fonction actuelle. Il pourrait s'agir d'un compte détenu externe (EOA) ou d'un autre contrat. C'est la variable la plus couramment utilisée pour déterminer qui a initié l'interaction actuelle avec le contrat.
Tx.origin , en revanche, représente l'expéditeur d'origine de la transaction, quel que soit le nombre d'appels intermédiaires. Il revient à l'EOA qui a initié la chaîne de transactions.
Comment MSG.Sender fonctionne dans les contrats intelligents
Lorsqu'une fonction dans un contrat de solidité est appelée, la variable MSG.Sender est définie sur l'adresse qui a directement invoqué la fonction. Cela en fait une source fiable pour identifier l'appelant immédiat dans le contrôle d'accès ou la logique basée sur l'autorisation.
Par exemple:
pragma solidity ^0.8.0;Exemple de contrat {address public owner; constructor() { owner = msg.sender; } function changeOwner(address newOwner) public { require(msg.sender == owner, 'Only the owner can change ownership'); owner = newOwner; }}
Dans ce contrat, le MSG.Sender garantit que seul le propriétaire actuel peut appeler la fonction changeOwner . Si un autre contrat appelle cette fonction au nom de quelqu'un d'autre, Msg.Sender sera ce contrat, pas l'utilisateur d'origine.
Comment fonctionne tx.origin dans les contrats intelligents
La variable tx.origin pointe toujours vers le compte appartenant à l'extérieur (EOA) qui a lancé l'intégralité de la transaction, même si plusieurs appels de contrat sont effectués entre les deux. Il est utile lorsque vous avez besoin de connaître l'utilisateur d'origine derrière une transaction, en particulier dans les interactions contractuelles complexes.
Voici un exemple pour illustrer son comportement:
pragma solidity ^0.8.0;contracter un {function callB(B _b) public { _b.checkOrigin(); }}
contrat b {
function checkOrigin() public { emit LogOrigin(msg.sender, tx.origin); }}
Dans ce scénario, si un EOA appelle callB à partir du contrat A, alors:
- MSG.Sender Inside
checkOrigin()sera l'adresse du contrat A. - Tx.origin sera l'EOA qui a commencé la transaction.
Cette distinction est cruciale lors de la conception de la logique qui dépend de la connaissance de l' utilisateur d'origine plutôt que du contrat intermédiaire.
Implications de sécurité de l'utilisation de tx.origin
L'utilisation de tx.origin peut introduire des risques de sécurité dans certaines situations. L'une des principales préoccupations est les attaques de phishing , où un contrat malveillant intime les utilisateurs à appeler une fonction qui effectue des actions sensibles en fonction de l'expéditeur d'origine.
Par exemple:
function transferFromUser(address to, uint amount) public {if (tx.origin == trustedUser) { // Perform transfer }
}
Un contrat malveillant pourrait inciter trustedUser à initier une transaction qui appelle cette fonction, permettant à l'attaquant de contourner les chèques qui reposent sur tx.origin .
Par conséquent, il est généralement recommandé d'utiliser MSG.Sender pour le contrôle d'accès, sauf si vous avez une raison spécifique d'utiliser Tx.origin .
Cas d'utilisation pratiques pour msg.sender et tx.origin
Bien que Msg.Sender soit largement utilisé dans les fonctions de contrat standard telles que les vérifications de propriété, le contrôle d'accès et les transferts de jetons, TX.Origin a plus d'applications de niche.
Utilisez Msg.Sender lorsque:
- Vous devez savoir qui a appelé la fonction actuelle.
- Vous implémentez des modificateurs d'accès comme
onlyOwner. - Vous souhaitez empêcher les contrats non autorisés d'interagir avec votre contrat.
Utilisez tx.origin lorsque:
- Vous souhaitez identifier l'utilisateur d'origine initiant la transaction.
- Vous implémentez une logique qui ne doit pas être déclenchée par d'autres contrats.
- Vous construisez des systèmes comme des programmes de référence ou des parachutistes qui nécessitent une interaction directe des utilisateurs.
Cependant, soyez toujours prudent avec Tx.origin en raison de son potentiel d'utilisation abusive et de la vulnérabilité aux attaques de phishing.
Meilleures pratiques et recommandations
Lorsque vous développez des contrats intelligents, suivez ces meilleures pratiques pour éviter les pièges courants:
- Préférez Msg.Sender à Tx.origin, sauf si vous avez une raison impérieuse de faire autrement.
- Comprenez le flux d'appel de vos contrats et comment le changement MSG.Sender et Tx.origin pendant l'exécution.
- Utilisez TX.origin uniquement dans les scénarios où vous devez vous assurer que l'acteur d'origine est un EOA.
- Audit votre code pour toute utilisation de Tx.origin et évaluez s'il introduit un risque inutile.
En comprenant les nuances entre MSG.Sender et Tx.origin , les développeurs peuvent écrire des contrats intelligents plus sûrs et prévisibles.
Questions fréquemment posées
Q: MSG.Sender peut-il être une adresse de contrat? Oui, Msg.Sender peut être soit un compte détenu externe (EOA), soit une adresse de contrat, selon qui a appelé la fonction. Si un contrat invoque une fonction dans un autre contrat, le MSG.Sender sera l'adresse du contrat d'appel.
Q: Tx.origin est-il toujours un EOA? Oui, Tx.origin est toujours le compte appartenant à l'extérieur (EOA) qui a lancé la transaction. Même si plusieurs contrats sont impliqués dans la chaîne d'appels, Tx.origin reste l'adresse utilisateur d'origine.
Q: Tx.origin peut-il être manipulé? Bien que Tx.origin ne puisse pas être forgé directement, il peut être exploité dans les attaques de phishing. Par exemple, un contrat malveillant peut inciter un utilisateur à déclencher une transaction qui effectue une action involontaire, en s'appuyant sur la vérification tx.origin pour l'autorisation.
Q: Dois-je éviter d'utiliser tx.origin dans mes contrats? Il est généralement plus sûr d'éviter d'utiliser tx.origin sauf si nécessaire. Étant donné qu'il peut être utilisé de manière à compromettre la sécurité, de nombreuses meilleures pratiques recommandent d'utiliser MSG.Sender pour le contrôle d'accès et les fonctions de changement d'état.
Clause de non-responsabilité:info@kdj.com
Les informations fournies ne constituent pas des conseils commerciaux. kdj.com n’assume aucune responsabilité pour les investissements effectués sur la base des informations fournies dans cet article. Les crypto-monnaies sont très volatiles et il est fortement recommandé d’investir avec prudence après une recherche approfondie!
Si vous pensez que le contenu utilisé sur ce site Web porte atteinte à vos droits d’auteur, veuillez nous contacter immédiatement (info@kdj.com) et nous le supprimerons dans les plus brefs délais.
-
RAIN Échangez maintenant$0.007852
113.00%
-
PIPPIN Échangez maintenant$0.06097
51.96%
-
PARTI Échangez maintenant$0.1396
42.04%
-
WAVES Échangez maintenant$0.9141
41.69%
-
ARC Échangez maintenant$0.04302
35.73%
-
HONEY Échangez maintenant$0.01029
21.80%
- Super Bowl LX : Teddy Swims, Green Day et un ensemble de tirages d'héritage pour l'extravagance 2026
- 2026-02-05 07:20:02
- Fantasy Football Premier League Round 25 : choix des joueurs clés, astuces et conseils pour une performance optimale de l'équipe
- 2026-02-05 07:15:02
- Remittix lance la plateforme PayFi avec une généreuse offre de bonus de 300 %, suscitant l'enthousiasme des investisseurs
- 2026-02-05 07:05:01
- FirstEnergy plante des milliers d'arbres, cultivant des communautés plus vertes dans six États
- 2026-02-05 07:15:02
- Big Apple Bets : Déballage des derniers bonus sans dépôt, bonus de casino et frénésie de tours gratuits
- 2026-02-05 07:10:01
- Nubank, Enova et Interactive Brokers : naviguer dans l'avenir de la finance
- 2026-02-05 07:10:01
Connaissances connexes
Comment gérer les émotions et le « trading de vengeance » dans les contrats à terme ?
Feb 05,2026 at 12:19am
Comprendre les déclencheurs émotionnels sur les marchés à terme 1. La volatilité des marchés a un impact direct sur les états psychologiques, amplifia...
Comment utiliser le profil de volume pour trouver les niveaux d’entrée clés des contrats à terme ?
Feb 04,2026 at 11:39pm
Comprendre la structure du profil de volume 1. Le profil de volume affiche la répartition du volume négocié à des niveaux de prix spécifiques sur une ...
Comment maximiser l’efficacité du capital à l’aide du trading sur marge croisée ?
Feb 05,2026 at 12:40am
Fondamentaux du trading sur marge croisée 1. Le trading sur marge croisée permet aux traders d'utiliser l'intégralité du solde de leur compte ...
Comment utiliser les moyennes mobiles exponentielles (EMA) pour suivre les tendances à terme ?
Feb 05,2026 at 04:40am
Comprendre les mécanismes de l'EMA sur les marchés à terme 1. Les moyennes mobiles exponentielles attribuent plus de poids aux données de prix réc...
Comment utiliser les alertes TradingView pour exécuter automatiquement des transactions à terme ?
Feb 04,2026 at 09:00pm
Configuration des alertes TradingView pour les contrats à terme 1. Connectez-vous à votre compte TradingView et ouvrez le graphique de l'instrumen...
Comment utiliser les ordres de profit automatisés pour des gains passifs ?
Feb 05,2026 at 06:00am
Comprendre les mécanismes de prise de profit automatisés 1. Les ordres de prise de profit automatisés sont des instructions préconfigurées qui exécute...
Comment gérer les émotions et le « trading de vengeance » dans les contrats à terme ?
Feb 05,2026 at 12:19am
Comprendre les déclencheurs émotionnels sur les marchés à terme 1. La volatilité des marchés a un impact direct sur les états psychologiques, amplifia...
Comment utiliser le profil de volume pour trouver les niveaux d’entrée clés des contrats à terme ?
Feb 04,2026 at 11:39pm
Comprendre la structure du profil de volume 1. Le profil de volume affiche la répartition du volume négocié à des niveaux de prix spécifiques sur une ...
Comment maximiser l’efficacité du capital à l’aide du trading sur marge croisée ?
Feb 05,2026 at 12:40am
Fondamentaux du trading sur marge croisée 1. Le trading sur marge croisée permet aux traders d'utiliser l'intégralité du solde de leur compte ...
Comment utiliser les moyennes mobiles exponentielles (EMA) pour suivre les tendances à terme ?
Feb 05,2026 at 04:40am
Comprendre les mécanismes de l'EMA sur les marchés à terme 1. Les moyennes mobiles exponentielles attribuent plus de poids aux données de prix réc...
Comment utiliser les alertes TradingView pour exécuter automatiquement des transactions à terme ?
Feb 04,2026 at 09:00pm
Configuration des alertes TradingView pour les contrats à terme 1. Connectez-vous à votre compte TradingView et ouvrez le graphique de l'instrumen...
Comment utiliser les ordres de profit automatisés pour des gains passifs ?
Feb 05,2026 at 06:00am
Comprendre les mécanismes de prise de profit automatisés 1. Les ordres de prise de profit automatisés sont des instructions préconfigurées qui exécute...
Voir tous les articles














