为什么合约里尽量避免使用 tx.origin
contract MyContract {
    address owner;
    function MyContract() public {
        owner = msg.sender;
    }
    function sendTo(address receiver, uint amount) public {
        require(tx.origin == owner);
        receiver.transfer(amount);
    }
}
contract AttackingContract {
    MyContract myContract;
    address attacker;
    function AttackingContract(address myContractAddress) public {
        myContract = MyContract(myContractAddress);
        attacker = msg.sender;
    }
    function() public {
        myContract.sendTo(attacker, msg.sender.balance);
    }
}
 
                如果觉得我的文章对您有用,请随意打赏。你的支持将鼓励我继续创作!