智能合约 实例一

编写一个简单的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。在我们的例子中,输出哈希值是相同的。

你可能感兴趣的:(智能合约 实例一)