2

我正在尝试更改区块链中合同中变量的值。我已经扣除了它的代码,是这样的:

pragma solidity ^0.4.8;
contract Trial {
   address public owner;
   address public person;
   uint initialEther;
   function Trial(address _person) payable {
       owner = msg.sender;
       person = _person;
       initialEther = msg.value;
   }
   modifier only_person() {
       if (msg.sender!=person && tx.origin!=person) throw;
       _;
   }


   function() payable {}  

   bytes4 public signature = bytes4(sha3("libraryFunction()"));
   bool variableToBeChanged = false;
   function libraryInvocation(address libraryAddress) only_person {
       bool doSomething = libraryAddress.delegatecall(signature);
       if (variableToBeChanged) {
           .....
      }
   }
}

假设我有正确的库函数签名,我要做的是更改“variableToBeChanged”的值,以便执行 if 中的代码。可能有一种方法可以使用具有正确名称的函数创建一个库,并以某种方式插入汇编代码来更改变量的值。但这就像用原子弹杀死一只蚂蚁。我正在寻找更简单的方法来做到这一点。我也知道这份合同不安全,我试图了解这是否可能,并且我想了解这对一份合同来说有多大风险。

4

1 回答 1

4

如果没有函数更改变量,这是不可能的。一旦部署了合约代码,它就是最终的,无法更改。您需要部署一个新合约。

您可以通过检查特定钱包地址的 msg.sender 属性来控制允许哪个钱包调用该函数的合约。

address owner = 0x2FD4...;
if(msg.sender != owner) throw;
        //code afterwards)
于 2017-04-22T18:16:01.880 回答