编写一个简单的ProofofExistence的智能合约。 主要思想就是创建一个数字公证:它存储了文档的哈希值作为存在的证明。
合约代码:
pragma solidity ^0.4.4;
// Proof of Existence contract, version 1
contract ProofOfExistence1 {
// state
bytes32 public proof;
// calculate and store the proof for a document
// *transactional function*
function notarize(string document) {
proof = proofFor(document);
}
// helper function to get a document's sha256
// *read-only function*
function proofFor(string document) constant returns (bytes32) {
return sha256(document);
}
}
智能合约的编译和部署参上篇文章,这面主要讲下与智能合约的交互
truffle(development)> var poe = ProofOfExistence1.at(ProofOfExistence1.address)
undefined
truffle(development)> poe.address
'0xecdac442b19290e8ac058dd49970b848231a9078'
truffle(development)> poe.notarize('An amazing idea')
{ tx: '0x77d96b21396a1a544d860840c36fc936a5871cd2405a28b70bcee4058dc725af',
receipt:
{ transactionHash: '0x77d96b21396a1a544d860840c36fc936a5871cd2405a28b70bcee4058dc725af',
transactionIndex: 0,
blockHash: '0xd66915a711878a09035506aa05c97508914fde8763c683c524b7692c0efcb07c',
blockNumber: 5,
gasUsed: 44198,
cumulativeGasUsed: 44198,
contractAddress: null,
logs: [],
status: 1 },
logs: [] }
truffle(development)> poe.proofFor('An amazing idea')
'0xa3287ff8d1abde95498962c4e1dd2f50a9f75bd8810bd591a64a387b93580ee7'
truffle(development)> poe.proof()
'0xa3287ff8d1abde95498962c4e1dd2f50a9f75bd8810bd591a64a387b93580ee7'
1. 首先是要获取部署的合约存入到poe的变量中。然后调用交易函数notarize,它包含了一个状态的改变。当我们调用一个交易函数时,我们获得了一个promise来解析一个交易对象,而不是实际的函数返回。改变EVM的状态我们需要支付gas,然后对网络发送一笔交易。这就是为什么我们得到一个交易信息对象作为promise的结果,指的是这种状态改变的交易。在这种情况下,我们对交易ID不感兴趣,所以我们不用考虑promise。在编写一个真正的应用程序的时候,我们需要保存它来检查生成的交易并捕获错误。
2. 接下来,我们调用只读(常量)函数proofFor。一定要使用关键字constant来标记只读函数,否则Truffle将尝试创建一笔交易来执行他们。这是一种告诉truffle我们不会和区块链进行交互而仅仅是读取值。使用这个只读函数,我们获得了文档的哈希值。
3. 我们现在需要将其与我们的智能合约的状态形成对比。要检查状态是否正确改变,我们需要读取证明公共状态变量。为了获得一个公共状态变量的值,我们可以调用一个同名的函数,它返回一个值的Promise。在我们的例子中,输出哈希值是相同的。