美文网首页智能合约
智能合约 实例一

智能合约 实例一

作者: 酷酷de熊 | 来源:发表于2018-04-11 10:12 被阅读0次

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

    相关文章

      网友评论

        本文标题:智能合约 实例一

        本文链接:https://www.haomeiwen.com/subject/udkahftx.html