-
Bitcoin
$118500
0.82% -
Ethereum
$3693
-0.03% -
XRP
$3.477
0.30% -
Tether USDt
$1.000
0.00% -
BNB
$794.9
4.79% -
Solana
$200.2
0.51% -
USDC
$0.9998
-0.01% -
Dogecoin
$0.2615
-1.16% -
Cardano
$0.8738
-0.04% -
TRON
$0.3176
2.58% -
Hyperliquid
$44.40
1.67% -
Stellar
$0.4687
2.42% -
Sui
$3.965
2.11% -
Chainlink
$19.30
0.97% -
Hedera
$0.2687
1.17% -
Avalanche
$25.31
-0.74% -
Bitcoin Cash
$524.6
1.06% -
Litecoin
$117.8
2.22% -
Shiba Inu
$0.00001506
-0.08% -
UNUS SED LEO
$8.979
-0.07% -
Toncoin
$3.297
1.19% -
Polkadot
$4.454
1.43% -
Uniswap
$10.58
1.39% -
Ethena USDe
$1.001
0.01% -
Monero
$324.5
1.37% -
Pepe
$0.00001390
0.22% -
Bitget Token
$4.816
0.51% -
Dai
$0.0000
0.01% -
Aave
$302.9
-2.70% -
Bittensor
$446.7
2.73%
MSG.Sender와 TX.origin의 차이점은 무엇입니까?
이더 리움 스마트 계약에서`msg.sender '는 즉각적인 발신자를 식별하는 반면,`tx.origin`은 원래 트랜잭션 이니셔티브로 추적되며, 각각의 독특한 보안 및 논리 목적을 제공합니다.
2025/07/23 18:28

이더 리움 스마트 계약 실행의 기본 이해
이더 리움 블록 체인 에서 스마트 계약은 거래 및 기능 통화를 통해 사용자 및 기타 계약과 상호 작용합니다. 견고성을 사용하여 스마트 계약을 개발하거나 분석 할 때 MSG.Sender 와 TX.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;
계약 a {function callB(B _b) public { _b.checkOrigin(); }
}
계약 B {
function checkOrigin() public { emit LogOrigin(msg.sender, tx.origin); }
}
이 시나리오에서 EOA가 계약 A에서 callB
호출하는 경우 :
- msg.sender 내부의
checkOrigin()
은 계약 A의 주소가됩니다. - TX.origin은 거래를 시작한 EOA가 될 것입니다.
이 차이는 중간 계약보다는 원래 사용자를 아는 데 의존하는 논리를 설계 할 때 중요합니다.
TX.origin 사용에 대한 보안 영향
TX.origin을 사용하면 특정 상황에서 보안 위험을 도입 할 수 있습니다. 주요 관심사 중 하나는 피싱 공격 으로 악의적 인 계약이 사용자에게 원래 발신자를 기반으로 민감한 작업을 수행하는 기능을 호출하도록 속이는 것입니다.
예를 들어:
function transferFromUser(address to, uint amount) public {
if (tx.origin == trustedUser) { // Perform transfer }
}
악의적 인 계약은 trustedUser
가이 기능을 호출하는 거래를 시작하도록 속일 수 있으며, 공격자는 TX.origin 에 의존하는 점검을 우회 할 수 있습니다.
따라서 TX.origin을 사용해야 할 특정 이유가없는 한 Access Control을 위해 MSG.Sender를 사용하는 것이 일반적으로 권장됩니다.
MSG.Sender 및 TX.origin의 실제 사용 사례
MSG.Sender 는 소유권 검사, 액세스 제어 및 토큰 전송과 같은 표준 계약 기능에서 널리 사용되지만 TX.Origin에는 더 많은 틈새 응용 프로그램이 있습니다.
MSG.Sender를 사용하십시오.
- 누가 현재 함수를 불렀는지 알아야합니다.
-
onlyOwner
와 같은 액세스 수정자를 구현하고 있습니다. - 무단 계약이 계약과 상호 작용하는 것을 방지하려고합니다.
다음과 같은 경우 tx.origin을 사용하십시오.
- 트랜잭션을 시작하는 원래 사용자를 식별하려고합니다.
- 다른 계약에 의해 트리거되어서는 안되는 논리를 구현하고 있습니다.
- 직접 사용자 상호 작용이 필요한 추천 프로그램 또는 에어 드롭과 같은 시스템을 구축하고 있습니다.
그러나 피싱 공격에 대한 오용과 취약성으로 인해 항상 TX.origin 에주의하십시오.
모범 사례 및 권장 사항
현명한 계약을 개발할 때는 이러한 모범 사례를 따르십시오. 일반적인 함정을 피하십시오.
- 달리 할 수있는 강력한 이유가 없다면 MSG.Sender를 선호 하십시오.
- 계약의 통화 흐름과 MSG.Sender 및 TX.origin이 실행하는 동안 어떻게 변경되는지 이해하십시오.
- 원래 배우가 EOA인지 확인 해야하는 시나리오에서만 TX.origin을 사용하십시오.
- TX.origin 사용에 대한 코드를 감사하고 불필요한 위험을 도입하는지 평가하십시오.
MSG.Sender 와 TX.origin 의 뉘앙스를 이해함으로써 개발자는보다 안전하고 예측 가능한 스마트 계약을 작성할 수 있습니다.
자주 묻는 질문
Q : MSG.Sender가 계약 주소가 될 수 있습니까?
예, MSG.Sender는 기능을 호출 한 사람에 따라 외부 소유 계정 (EOA) 또는 계약 주소가 될 수 있습니다. 계약이 다른 계약에서 기능을 호출하면 MSG.Sender 는 전화 계약의 주소가됩니다.
Q : TX.origin은 항상 EOA입니까?
예, TX.origin은 항상 거래를 시작한 외부 소유 계정 (EOA) 입니다. Call Chain에 여러 계약이 관여하더라도 TX . Origin은 원래 사용자 주소로 남아 있습니다.
Q : TX.origin을 조작 할 수 있습니까?
TX.origin은 직접 위조 할 수는 없지만 피싱 공격에서 악용 될 수 있습니다. 예를 들어, 악의적 인 계약은 사용자가 의도하지 않은 조치를 수행하는 거래를 트리거하여 TX.origin 확인에 의존하여 승인을받을 수 있습니다.
Q : 계약에서 TX.origin을 사용하지 않아야합니까?
절대적으로 필요하지 않는 한 TX.origin을 사용하지 않는 것은 일반적으로 더 안전합니다. 보안을 손상시키는 방식으로 사용될 수 있으므로 많은 모범 사례는 액세스 제어 및 상태 변화 기능을 위해 MSG.Sender를 사용하는 것이 좋습니다.
부인 성명:info@kdj.com
제공된 정보는 거래 조언이 아닙니다. kdj.com은 이 기사에 제공된 정보를 기반으로 이루어진 투자에 대해 어떠한 책임도 지지 않습니다. 암호화폐는 변동성이 매우 높으므로 철저한 조사 후 신중하게 투자하는 것이 좋습니다!
본 웹사이트에 사용된 내용이 귀하의 저작권을 침해한다고 판단되는 경우, 즉시 당사(info@kdj.com)로 연락주시면 즉시 삭제하도록 하겠습니다.
- H100 Group의 Bitcoin Bet : Cryptocurrency의 미래로 대담한 이동
- 2025-07-24 00:30:13
- Efsane : 투자 플랫폼으로서 암호화 생태계의 미래를 개척
- 2025-07-24 00:30:13
- Sui Price, 공개이자 및 $ 4의 탈주 : Sui Surge는?
- 2025-07-23 22:50:13
- Blockdag, XRP 및 DOT : 월스트리트 프로처럼 암호화 웨이브 타기
- 2025-07-23 23:10:13
- Dogecoin, Hedera 및 Payfi : 2025 년에 Altcoins가 뜨거워졌습니다
- 2025-07-23 23:50:12
- NFT Penguins Rally : Pengu의 상승과 Cryptobatz Bounce
- 2025-07-23 23:10:13
관련 지식

내 비트 스탬프 선물 포지션이 청산되는 이유는 무엇입니까?
2025-07-23 11:08:15
비트 스탬프의 선물 청산 이해 비트 스탬프 에서의 선물 거래에는 자금을 빌려서 레버리지 직책을 개방하는 것이 포함되며, 이는 잠재적 이익과 위험을 모두 증폭시킵니다. 마진 잔액이 필요한 유지 보수 임계 값 아래로 떨어지면 Bitstamp는 차용 금액을 포함하기 위해 청...

Bitstamp는 역 계약을 제공합니까?
2025-07-23 13:28:52
암호 화폐 거래에서 역 계약 이해 cryptocurrency 파생 상품의 영역에서, 역 계약은 스테이블 코인 또는 피아트 통화가 아니라 BTC 또는 ETH 와 같은 기본 암호 화폐로 정착 및 담보가 표시되는 특정 유형의 선물 또는 영구 계약입니다. 이는 상인이 역 계약...

비트 스탬프 선물 무역 기록을 찾는 방법은 무엇입니까?
2025-07-23 08:07:56
비트 스탬프 및 선물 거래 가용성 이해 Bitstamp의 서비스 제공의 현재 상태에 따라 Bitstamp가 선물 거래를 지원하지 않음 을 명확히하는 것이 중요합니다. 이 플랫폼은 주로 Spot Cryptocurrency Exchange로 기능하며, 사용자는 현재 시장 ...

비트 스탬프 선물에서 후행 정지를 사용할 수 있습니까?
2025-07-23 13:42:32
암호 화폐 거래에서 후행 중지를 이해합니다 후행 정지는 자산 가격이 유리한 방향으로 이동함에 따라 자동으로 조정되는 동적 유형의 스톱 손실 순서입니다. 정해진 가격 수준으로 고정 된 표준 정지 손실과 달리, 후행 정지는 시장 가격을 지정된 백분율 또는 달러 금액으로 따...

비트 스탬프 계약의 최소 거래 규모는 얼마입니까?
2025-07-23 19:14:52
비트 스탬프 및 계약 오퍼링을 이해합니다 Bitstamp는 2011 년에 설립 된 가장 긴 암호 화폐 거래소 중 하나이며 보안, 규제 준수 및 사용자 접근성에 중점을 둡니다. Bitstamp는 주로 스팟 거래 플랫폼으로 운영되지만 사용자는 종종 계약 거래 , 특히 선물...

비트 스탬프에서 윤리적 인 영구를 교환하는 방법은 무엇입니까?
2025-07-23 03:28:57
윤리적 계약 이해 ETH 영구 계약은 거래자가 기본 자산을 소유하지 않고 이더 리움 가격을 추측 할 수있는 파생 상품입니다. 전통적인 미래와 달리,이 계약에는 만료 날짜가 없으므로 거래자가 자리를 무기한 상태로 유지할 수 있습니다. Bitstamp는 레버리지와 함께 윤...

내 비트 스탬프 선물 포지션이 청산되는 이유는 무엇입니까?
2025-07-23 11:08:15
비트 스탬프의 선물 청산 이해 비트 스탬프 에서의 선물 거래에는 자금을 빌려서 레버리지 직책을 개방하는 것이 포함되며, 이는 잠재적 이익과 위험을 모두 증폭시킵니다. 마진 잔액이 필요한 유지 보수 임계 값 아래로 떨어지면 Bitstamp는 차용 금액을 포함하기 위해 청...

Bitstamp는 역 계약을 제공합니까?
2025-07-23 13:28:52
암호 화폐 거래에서 역 계약 이해 cryptocurrency 파생 상품의 영역에서, 역 계약은 스테이블 코인 또는 피아트 통화가 아니라 BTC 또는 ETH 와 같은 기본 암호 화폐로 정착 및 담보가 표시되는 특정 유형의 선물 또는 영구 계약입니다. 이는 상인이 역 계약...

비트 스탬프 선물 무역 기록을 찾는 방법은 무엇입니까?
2025-07-23 08:07:56
비트 스탬프 및 선물 거래 가용성 이해 Bitstamp의 서비스 제공의 현재 상태에 따라 Bitstamp가 선물 거래를 지원하지 않음 을 명확히하는 것이 중요합니다. 이 플랫폼은 주로 Spot Cryptocurrency Exchange로 기능하며, 사용자는 현재 시장 ...

비트 스탬프 선물에서 후행 정지를 사용할 수 있습니까?
2025-07-23 13:42:32
암호 화폐 거래에서 후행 중지를 이해합니다 후행 정지는 자산 가격이 유리한 방향으로 이동함에 따라 자동으로 조정되는 동적 유형의 스톱 손실 순서입니다. 정해진 가격 수준으로 고정 된 표준 정지 손실과 달리, 후행 정지는 시장 가격을 지정된 백분율 또는 달러 금액으로 따...

비트 스탬프 계약의 최소 거래 규모는 얼마입니까?
2025-07-23 19:14:52
비트 스탬프 및 계약 오퍼링을 이해합니다 Bitstamp는 2011 년에 설립 된 가장 긴 암호 화폐 거래소 중 하나이며 보안, 규제 준수 및 사용자 접근성에 중점을 둡니다. Bitstamp는 주로 스팟 거래 플랫폼으로 운영되지만 사용자는 종종 계약 거래 , 특히 선물...

비트 스탬프에서 윤리적 인 영구를 교환하는 방법은 무엇입니까?
2025-07-23 03:28:57
윤리적 계약 이해 ETH 영구 계약은 거래자가 기본 자산을 소유하지 않고 이더 리움 가격을 추측 할 수있는 파생 상품입니다. 전통적인 미래와 달리,이 계약에는 만료 날짜가 없으므로 거래자가 자리를 무기한 상태로 유지할 수 있습니다. Bitstamp는 레버리지와 함께 윤...
모든 기사 보기
