時価総額: $2.585T -2.36%
ボリューム(24時間): $167.5827B 6.93%
恐怖と貪欲の指数:

17 - 極度の恐怖

  • 時価総額: $2.585T -2.36%
  • ボリューム(24時間): $167.5827B 6.93%
  • 恐怖と貪欲の指数:
  • 時価総額: $2.585T -2.36%
暗号
トピック
暗号化
ニュース
暗号造園
動画
トップクリプトスペディア

言語を選択する

言語を選択する

通貨の選択

暗号
トピック
暗号化
ニュース
暗号造園
動画

msg.senderと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.

2025/07/23 18:28

Ethereumスマートコントラクトの実行の基本を理解する

Ethereumブロックチェーンでは、スマートコントラクトは、トランザクションや関数呼び出しを通じて、ユーザーやその他の契約と対話します。 Solidityを使用してスマートコントラクトを開発または分析する場合、 MSG.SenderTx.Originの違いを理解することが不可欠です。どちらも、契約の実行中に住所情報を取得するために使用されるグローバル変数ですが、それらは異なる目的を果たし、さまざまなコンテキストで異なる動作をします。

MSG.Senderは、現在の関数の直接の発信者を指します。これは、外部所有のアカウント(EOA)または別の契約です。これは、契約との現在の相互作用を誰が開始したかを決定するために最も一般的に使用される変数です。

一方、 Tx.Originは、何回の中間呼び出しが発生したかに関係なく、トランザクションの元の送信者を表します。トランザクションチェーンを開始したEOAにまでさかのぼります。

MSG.Senderがスマートコントラクトでどのように機能するか

堅牢性契約の関数が呼び出されると、 msg.sender変数が関数を直接呼び出したアドレスに設定されます。これにより、アクセス制御または許可ベースのロジックで即時発信者を識別するための信頼できるソースになります。

例えば:

 pragma solidity ^0.8.0;契約例{




address public owner; constructor() { owner = msg.sender; } function changeOwner(address newOwner) public { require(msg.sender == owner, 'Only the owner can change ownership'); owner = newOwner; }

}

この契約では、 MSG.Senderは、現在の所有者のみがchangeOwner関数を呼び出すことができることを保証します。別の契約が他の誰かに代わってこの関数を呼び出す場合、 MSG.Senderは元のユーザーではなくその契約になります。

Tx.Originがスマートコントラクトでどのように機能するか

Tx.Origin変数は、複数の契約呼び出しが行われたとしても、トランザクション全体を開始した外部所有アカウント(EOA)を常に指しています。これは、特に複雑な契約相互作用において、トランザクションの背後にある元のユーザーを知る必要がある場合に役立ちます。

その動作を説明する例は次のとおりです。

 pragma solidity ^0.8.0;契約{




function callB(B _b) public { _b.checkOrigin(); }

}

契約B {

function checkOrigin() public { emit LogOrigin(msg.sender, tx.origin); }

}

このシナリオでは、EOAが契約AからcallBを呼び出す場合、次のとおりです。

  • MSG.SENDER INSIND checkOrigin()は契約Aのアドレスになります。
  • Tx.Originは、トランザクションを開始したEOAになります。

この区別は、中間契約ではなく元のユーザーを知ることに依存するロジックを設計する場合に重要です。

Tx.originを使用することのセキュリティへの影響

Tx..originを使用すると、特定の状況でセキュリティリスクを導入できます。主な懸念事項の1つはフィッシング攻撃です。そこでは、悪意のある契約により、ユーザーは元の送信者に基づいて機密アクションを実行する関数を呼び出すようになります。

例えば:

 function transferFromUser(address to, uint amount) public { if (tx.origin == trustedUser) { // Perform transfer }

}

悪意のある契約により、 trustedUserこの関数を呼び出すトランザクションを開始し、攻撃者がTx.Originに依存するチェックをバイパスできるようになります。

したがって、 Tx.Originを使用する特定の理由がない限り、アクセス制御にMSG.Senderを使用することを一般的に推奨します。

MSG.SENDERおよびTX.ORIGINの実用的なユースケース

MSG.Senderは、所有権チェック、アクセス制御、トークン転送などの標準的な契約関数で広く使用されていますが、 Tx.Originにはより多くのニッチアプリケーションがあります。

msg.senderを使用する場合:

  • 誰が現在の関数を呼んだかを知る必要があります。
  • onlyOwnerようなアクセス修飾子を実装しています。
  • 不正な契約が契約と対話するのを防ぎたいです。

tx.originを使用して:

  • トランザクションを開始する元のユーザーを特定する必要があります。
  • 他の契約によってトリガーされるべきではないロジックを実装しています。
  • 紹介プログラムや、直接ユーザーインタラクションを必要とするエアドロップなどのシステムを構築しています。

ただし、フィッシング攻撃に対する誤用と脆弱性の可能性があるため、 Tx.Originには常に慎重になります。

ベストプラクティスと推奨事項

スマートコントラクトを開発するときは、これらのベストプラクティスに従って、一般的な落とし穴を避けてください。

  • 特に魅力的な理由がない限り、 tx.originよりもmsg.senderを好む。
  • 契約のコールフローと、実行中のMSG.SENDERTX.ORIGINがどのように変化するかを理解してください。
  • 元の俳優がEOAであることを確認する必要があるシナリオでのみTx.Originを使用してください。
  • Tx.originを使用するためにコードを監査し、不必要なリスクをもたらすかどうかを評価します。

MSG.SenderTx.Originの間のニュアンスを理解することにより、開発者はより安全で予測可能なスマートコントラクトを書くことができます。


よくある質問

Q:msg.senderは契約アドレスになることができますか?はい、 msg.senderは、誰が関数を呼んだかに応じて、外部所有のアカウント(EOA)または契約アドレスのいずれかです。契約が別の契約で関数を呼び出す場合、 MSG.Senderは呼び出し契約のアドレスになります。

Q:tx.originは常にEOAですか?はい、 Tx.Originは常にトランザクションを開始した外部所有アカウント(EOA)です。複数の契約がコールチェーンに関与している場合でも、 Tx.Originは元のユーザーアドレスのままです。

Q:tx.originを操作できますか? Tx.Originは直接偽造できませんが、フィッシング攻撃で悪用される可能性があります。たとえば、悪意のある契約により、ユーザーは意図しないアクションを実行するトランザクションをトリガーし、 TX.ORIGIN Checkに依存して承認を得ることができます。

Q:契約でtx.originの使用を避けるべきですか?絶対に必要な場合を除き、 Tx.originの使用を避ける方が一般的に安全です。セキュリティを妥協する方法で使用できるため、多くのベストプラクティスは、アクセス制御および状態を変える機能にMSG.Senderを使用することを推奨しています。

免責事項:info@kdj.com

提供される情報は取引に関するアドバイスではありません。 kdj.com は、この記事で提供される情報に基づいて行われた投資に対して一切の責任を負いません。暗号通貨は変動性が高いため、十分な調査を行った上で慎重に投資することを強くお勧めします。

このウェブサイトで使用されているコンテンツが著作権を侵害していると思われる場合は、直ちに当社 (info@kdj.com) までご連絡ください。速やかに削除させていただきます。

関連知識

感情と先物における「リベンジ取引」を管理する方法?

感情と先物における「リベンジ取引」を管理する方法?

2026-02-05 00:19:32

先物市場における感情的なトリガーを理解する1. 市場のボラティリティは心理状態に直接影響を与え、急速な価格変動に基づいて恐怖や高揚感を増幅させることがよくあります。 2. 喪失は脳の脅威反応システムを活性化し、系統的な分析ではなく衝動的な決定を引き起こします。 3. ソーシャルメディアのフィードやグ...

出来高プロファイルを使用して主要な先物エントリーレベルを見つけるにはどうすればよいですか?

出来高プロファイルを使用して主要な先物エントリーレベルを見つけるにはどうすればよいですか?

2026-02-04 23:39:35

ボリュームプロファイル構造の理解1. 出来高プロファイルは、定義された期間にわたる特定の価格レベルでの取引高の分布を表示し、チャート上に水平方向のヒストグラムを形成します。 2. コントロールポイント (POC) は、出来高集中が最も高い価格レベルを表し、多くの場合、価格反転の磁石として機能します。...

クロスマージン取引を利用して資本効率を最大化するには?

クロスマージン取引を利用して資本効率を最大化するには?

2026-02-05 00:40:24

クロスマージン取引の基礎1. クロスマージン取引により、トレーダーは口座残高全体を複数の市場で同時にオープンポジションの担保として使用できます。 2. 各ポジションに専用のマージンプールがある独立マージンとは異なり、クロスマージンはウォレットに保持されているすべての資産から資本を動的に割り当てます。...

先物トレンドフォローに指数移動平均 (EMA) を使用するにはどうすればよいですか?

先物トレンドフォローに指数移動平均 (EMA) を使用するにはどうすればよいですか?

2026-02-05 04:40:17

先物市場におけるEMAの仕組みを理解する1. 指数移動平均は、最近の価格データにより大きな重みを割り当て、単純な移動平均よりも応答性が高くなります。 2. トレーダーは通常、9 期間、21 期間、および 50 期間の EMA を展開して、短期、中期、長期のモメンタムの変化を捉えます。 3. レバレッ...

TradingViewアラートを使用して先物取引を自動的に実行するにはどうすればよいですか?

TradingViewアラートを使用して先物取引を自動的に実行するにはどうすればよいですか?

2026-02-04 21:00:31

先物契約のTradingViewアラートの設定1. TradingView アカウントにログインし、Binance または Bybit の BTC/USD または ETH/USD 無期限など、目的の先物商品のチャートを開きます。 2. 好みのインジケーター、ローソク足の時間枠、描画ツールを使用してチ...

パッシブゲインのために自動利食い注文を使用するにはどうすればよいですか?

パッシブゲインのために自動利食い注文を使用するにはどうすればよいですか?

2026-02-05 06:00:03

自動化されたテイクプロフィットの仕組みを理解する1. 自動利食い注文は、資産が指定された価格レベルに達したときに売り取引を実行する事前設定された命令です。 2. これらの注文は取引所の注文帳に存在し、市場価格がトリガーするまで休眠状態になります。 3. 手動販売とは異なり、ユーザーの存在や感情的な干...

感情と先物における「リベンジ取引」を管理する方法?

感情と先物における「リベンジ取引」を管理する方法?

2026-02-05 00:19:32

先物市場における感情的なトリガーを理解する1. 市場のボラティリティは心理状態に直接影響を与え、急速な価格変動に基づいて恐怖や高揚感を増幅させることがよくあります。 2. 喪失は脳の脅威反応システムを活性化し、系統的な分析ではなく衝動的な決定を引き起こします。 3. ソーシャルメディアのフィードやグ...

出来高プロファイルを使用して主要な先物エントリーレベルを見つけるにはどうすればよいですか?

出来高プロファイルを使用して主要な先物エントリーレベルを見つけるにはどうすればよいですか?

2026-02-04 23:39:35

ボリュームプロファイル構造の理解1. 出来高プロファイルは、定義された期間にわたる特定の価格レベルでの取引高の分布を表示し、チャート上に水平方向のヒストグラムを形成します。 2. コントロールポイント (POC) は、出来高集中が最も高い価格レベルを表し、多くの場合、価格反転の磁石として機能します。...

クロスマージン取引を利用して資本効率を最大化するには?

クロスマージン取引を利用して資本効率を最大化するには?

2026-02-05 00:40:24

クロスマージン取引の基礎1. クロスマージン取引により、トレーダーは口座残高全体を複数の市場で同時にオープンポジションの担保として使用できます。 2. 各ポジションに専用のマージンプールがある独立マージンとは異なり、クロスマージンはウォレットに保持されているすべての資産から資本を動的に割り当てます。...

先物トレンドフォローに指数移動平均 (EMA) を使用するにはどうすればよいですか?

先物トレンドフォローに指数移動平均 (EMA) を使用するにはどうすればよいですか?

2026-02-05 04:40:17

先物市場におけるEMAの仕組みを理解する1. 指数移動平均は、最近の価格データにより大きな重みを割り当て、単純な移動平均よりも応答性が高くなります。 2. トレーダーは通常、9 期間、21 期間、および 50 期間の EMA を展開して、短期、中期、長期のモメンタムの変化を捉えます。 3. レバレッ...

TradingViewアラートを使用して先物取引を自動的に実行するにはどうすればよいですか?

TradingViewアラートを使用して先物取引を自動的に実行するにはどうすればよいですか?

2026-02-04 21:00:31

先物契約のTradingViewアラートの設定1. TradingView アカウントにログインし、Binance または Bybit の BTC/USD または ETH/USD 無期限など、目的の先物商品のチャートを開きます。 2. 好みのインジケーター、ローソク足の時間枠、描画ツールを使用してチ...

パッシブゲインのために自動利食い注文を使用するにはどうすればよいですか?

パッシブゲインのために自動利食い注文を使用するにはどうすればよいですか?

2026-02-05 06:00:03

自動化されたテイクプロフィットの仕組みを理解する1. 自動利食い注文は、資産が指定された価格レベルに達したときに売り取引を実行する事前設定された命令です。 2. これらの注文は取引所の注文帳に存在し、市場価格がトリガーするまで休眠状態になります。 3. 手動販売とは異なり、ユーザーの存在や感情的な干...

すべての記事を見る

User not found or password invalid

Your input is correct