以太坊私链与智能合约部署学习(博主修正篇)—— 第四篇

    本篇的主要内容是,通过geth发布自定义的智能合约,并进行合约调用。

    在最新的geth中,取消了eth.complie,所以网上很多资料都不能用了,但总体来说还是很有参考价值的。一路兜兜转转,终于调通了整个流程,特此分享。

    整个合约布署,整体看来分为以下四个步骤:

    1、用Solidity语言编写合约内容。(今天只入门hello world级别的合约,后续文章会对这个语言进行深入讨论)

    2、对合约类进行编译,获得abiDefinition和bytecode。(因为新版geth1.6中已取消了eth.compile,所以编译工作只能交由solc或https://ethereum.github.io/browser-solidity进行编译)

    3、通过abiDefinition和bytecode实例化合约并进行布署。

    4、通过合约地址,实例化自己的合约,并进行调用。

    现在围绕着这四个步骤展开描述,各位读者根据以下步骤可以调通整个过程,如果发现有不足之处,请及时指出。(注:本次实验基于windows进行)

 

    1、用Solidity语言编写合约内容

pragma solidity ^0.4.0;

contract test {
    function multiply(uint a) public returns(uint d) {
        return a * 7;
    }
}

    现在请先别纠结合约的语法。只要初步认识,这个合约传出一个整型数a,并返回a*7的结果。

 

    2、对合约类进行编译,获得abiDefinition和bytecode

    因为geth 1.6已经取消了eth.complie,所以合约的编译不能在geth中完成。只能通过solc或者在线工具https://ethereum.github.io/browser-solidity 完成。因为solc只能在linux下编译,当前我的实验环境是windows,所以选择了在线工具。

    用浏览器打开在线工具,并将步骤一的合约粘贴入工具左侧的文本区中,如下图所示:

    因为当前自动编译选项为勾选状态,所以工具会对合约进行自动编译。这时,我们需要点击“Details”按钮,便会看到以下的对话框弹出:

    

    红框中的两部分数据:bytecode和interface-abi便是我们需要的二进制码和abi接口定义。此时,我们点击界面上的复制按钮,把数据复制到本地。

 

    3、通过abiDefinition和bytecode实例化合约并进行布署

// 以下两段即是步骤二获取的abiDefinition和bytecode数据
abi=[{"constant":false,"inputs":[{"name":"a","type":"uint256"}],"name":"multiply","outputs":[{"name":"d","type":"uint256"}],"payable":false,"stateMutability":"nonpayable","type":"function"}]
bytecode
="0x6060604052341561000f57600080fd5b60b18061001d6000396000f300606060405260043610603f576000357c0100000000000000000000000000000000000000000000000000000000900463ffffffff168063c6888fa1146044575b600080fd5b3415604e57600080fd5b606260048080359060200190919050506078565b6040518082815260200191505060405180910390f35b60006007820290509190505600a165627a7a72305820e8baa72a4bd1ffe2e8fa51812e8d65fc7b145baf48382c4ae5039510fd35a6ff0029"
// 创建合约
var contract = eth.contract(abi);
var initializer = {from: web3.eth.accounts[0], data: bytecode, gas: 300000};
var token = contract.new(initializer)
// 合约创建完成之后,打印token.address为空
// 需要通过挖矿这一步骤,对合约地址进行确认
miner.start(4);
admin.sleepBlocks(2);
miner.stop();

    到此为止,合约的布署已布署到了区块链上。

 

    4、通过合约地址,实例化自己的合约,并进行调用

// 在合约调用之前,需要对用户进行解锁
personal.unlockAccount(eth.accounts[0],"123456")
mycontract = contract.at(token.address)
mycontract.multiply.call(2)    // 到了这一步,我们可以得到自己合约的返回值14

    到这里,合约的布署与调用大功告成。如果有疑问的同学,可以一起讨论。

 

 参考资料:

http://blog.csdn.net/Blossomps/article/details/59542586    以太坊私有链环境下智能合约部署流程

http://blog.csdn.net/super_wu1992/article/details/76919308    以太坊私有链创建及智能合约的部署和交互

http://blog.csdn.net/fidelhl/article/details/50481859    以太坊智能合约编程之菜鸟教程

http://8btc.com/article-4537-1.html        以太坊私链与智能合约部署入门教程

博主注:上面的文章,大部份只适用于旧版本的geth,给调通整个流程造成不小的障碍。不过依然感谢这些文章的作者,给后来的入门者提供参考的依据。虽然一路磕磕碰碰,但实验最终顺利通过,可喜可贺。

 

下一篇,我们将一起学习钱包账户的备份与转移,希望大家能一起进步:)

posted on 2017-11-22 16:29  咚..咚  阅读(3179)  评论(2编辑  收藏  举报

导航