如何在不同链部署地址完全相同的合约

在以太坊中,合约是一种特殊的账户,它没有私钥,只有代码。而合约的地址通常是由部署者的地址与nonce共同做keccak哈希生成的。具体的算法实际上就是:

contractAddress = keccak256(rlp.encode(deployingAddress, nonce))[12:]

对于那些需要在多个链部署的项目来说,如果保证部署者的地址相同,nonce相同,则可以部署出相同地址的合约。例如,Uniswap的UniswapV2Factory在Ethereum的主网、Ropsten、Rinkeby等均有相同的地址。

但是这种部署方式要求每个网的部署顺序要完全一致,以确保nonce相同。有没有办法能更好地部署不同链得到相同的地址呢?

答案是使用CREATE2指令。

CREATE2指令是以太坊EIP-1014引入的一种能预先计算合约地址的新的指令,它的算法如下:

contractAddress = keccak256(0xff + deployingAddress + salt + keccak256(bytecode))[12:]

只要保证deployingAddress和一个指定的salt不变,相同的合约代码(bytecode)部署后得到的合约地址就一定是相同的。

如果我们在不同的链首先部署一个能部署合约的合约,

猜你喜欢

转载自blog.csdn.net/FENGQIYUNRAN/article/details/127867982