1703876946
区块链项目开发指南 3.15 存在、真实性和所有权合约的证明
1703876947
1703876948
本节将编写一个不用出示实际文件就可以证明文件所有权的Solidity合约。它可以证明该文件在某个特定时间存在,并最终检查文件真实性(integrity)。
1703876949
1703876950
将成对存储文件哈希和所有者名字以实现所有权证明(Proof of Owernership,PoO),成对存储文件哈希和区块时间戳以实现存在证明(Proof of Existence,PoE)。最后,存储哈希自身证明文件真实性,也就是说,如果文件被修改了,则它的哈希会随之改变,合约就不能发现任何这样的文件了,由此证明文件被修改了。
1703876951
1703876952
相关智能合约的代码如下:
1703876953
1703876954
1703876955
1703876956
1703876957
1703876958
1703876959
1703876960
1703876961
1703876962
1703876964
区块链项目开发指南 3.16 编译和部署合约
1703876965
1703876966
以太坊提供了solc编译器,其中提供一个命令行界面编译.sol文件,请访问如下网址:http://solidity.readthedocs.io/en/develop/installing-solidity.html#binary-packages找到安装指南,并访问https://Solidity.readthedocs.io/en/develop/using-the-compiler.html找到使用指南。我们不会直接使用solc编译器;而是使用solcjs和Browser Solidity。Solcjs允许在node.js中以编程方式编译Solidity,而Browser Solidity是一个适用于小型合约的IDE(集成开发环境)。
1703876967
1703876968
现在使用以太坊提供的浏览器编译前面的合约。如需深入相关知识,请访问https://Ethereum.github.io/browser-Solidity/。用户还可以下载Browser Solidity源代码,并离线使用。请访问https://github.com/Ethereum/browser-Solidity/tree/gh-pages进行下载。
1703876969
1703876970
使用browser Solidity的主要优点是,它提供了一个编辑器(editor),并生成代码以部署合约。
1703876971
1703876972
在编辑器中,复制粘贴前面的合约代码。将看到它编译并提供web3.js代码,以使用geth交互操作台进行部署。
1703876973
1703876974
输出如下:
1703876975
1703876976
1703876977
1703876978
1703876979
1703876980
1703876981
1703876982
data代表EVM理解的字节码(bytecode)。源代码首先转换成opcode,然后再转换成字节码。每个opcode都有相关gas。
1703876983
1703876984
web3.eth.contract的第一个实参是ABI定义。在创建交易时使用ABI定义,因为它包含所有方法的原型。
1703876985
1703876986
现在在开发者模式下启用挖矿,运行geth。运行如下命令:
1703876987
1703876988
1703876989
1703876990
1703876991
现在打开另一个命令行窗口,在其中输入下面的命令,以打开geth的交互JavaScript操作台:
1703876992
1703876993
1703876994
[
上一页 ]
[ :1.703876945e+09 ]
[
下一页 ]