程序员

truffle - 介绍、编写和部署智能合约

2018-03-07  本文已影响0人  Jan_gogogo

 truffle是一款为了方便开发、调试、部署智能合约的框架,他集成了很多功能,大大减少了开发的时间,官方把他比作一个以太坊的瑞士军刀,官网地址:http://truffleframework.com
本系列文章将会介绍如何使用truffle框架对智能合约进行开发、调试、测试、部署。需要用到的工具有:

一、工具安装

1 .truffle

npm install -g truffle
  1. ganache(巧克力酱)
     ganache可以把他看做是你的节点服务,启动后节点服务随之启动,这样我们就不需要每次都通过控制台去启动节点,为了方便测试,系统会自动生成10个账户,而且每个账户里面有100个eth。
     界面第一个tab(ACCOUNTS)显示的是节点里面的账号信息,其他根据名称也可以猜到:BLOCKS是每个区块的信息,TRANSACTIONS是交易信息,LOGS是日志。
     最右边的设置项,可以设置节点的地址、网络id、端口、账户数、gas limit等。


    ganache界面
    配置界面

启动后,默认的地址是 http://127.0.0.1:7545,networkid:5777,我们就是用默认的就好,不需要改。

  1. Atom
    只是用来编写智能合约的,当然你也可以使用sublime代替,如果你是后端开发,直接在intellij安装个solidity的插件也可以,NB的人请直接用记事本来写。Atom默认不支持solidity,需要安装插件。
apm install linter #(if you don't have AtomLinter/Linter installed). 
apm install linter-solidity
//执行上面命令,安装 solidity插件
Atom界面

二、开发、部署

首先我们新建一个项目的目录batFamily,然后执行truffle的初始化

mkdir batFamily
cd batFamily
truffle init
中途下载文件失败了,无视就好

然后使用Atom打开我们刚创建的目录,发现多了几个文件夹和文件。



开始开发我们的第一个智能合约,这个智能合约有转账,查询余额两个功能。
切换到控制台:

truffle create contract BatCoin

以上命令创建一个名为BatCoin的合约文件,返回Atom会发现在contracts目录下多了一个BatCoin.sol文件,接着把以下代码拷贝进去

pragma solidity ^0.4.4;


contract BatCoin {
  address _creator;
  mapping(address => uint256) balances;

  /**
   * @dev 构造函数
   */
  function BatCoin() public{
    //指定合约的创建者
   _creator = msg.sender;
   //一开始把10000个币发给创建者
   balances[msg.sender] = 10000;
  }

  /**
   * @dev 转账
   * @param _to 金额接收人地址
   * @param _value 转账金额
   * @return 交易结果
   */
  function transfer(address _to,uint256 _value) public returns(bool){
    require(_to != address(0)); //地址不为空
    require(_value <= balances[msg.sender]); //金额是否足够完成交易
    balances[msg.sender] -=_value;
    balances[_to] += _value;
    return true;
  }

  /**
   * @dev 查账
   * @param _owner 查账地址
   * @return 账号余额
   */
  function balanceOf(address _owner) public view returns(uint256){
    return balances[_owner];
  }

  /**
   * @dev 回退函数
   */
  function () payable public{}
}

 合约已经写完了,然后启动ganache,启动成功后表示我们的节点服务已经启动,地址上面说了默认是 http://127.0.0.1:7545,networkid:5777(注意:ganache关闭后,节点服务的数据也会被清空)。
 回到Atom,打开truffle.js文件

module.exports = {
  // See <http://truffleframework.com/docs/advanced/configuration>
  // to customize your Truffle configuration!
   rpc: {
    host: "localhost",
    port: 8545
   },
   networks: {
        ganache:{
          host:"localhost",
          port:7545,
          network_id:"5777"
        }
    }
};

 这里只说明一下networks,表示可以配置很多个网络,因为我们需要连接到ganache的节点服务,所以配置一个ganache网络。

truffle console --network ganache //进入truffle控制台,使用定义的ganache网络

 ok,接下来可以执行编译命令了,这里的编译其实就是把sol文件转换成功json格式的文件,里面包含很多信息,其中有两个比较重要,一个是ABI信息,另一个是data(bytecode)信息。ABI是对合约的描述,例如告诉调用方合约名称是什么,里面有什么函数,入参是什么等。data(bytecode)是一串十六进制的机器码,是智能合约的代码,将会被EVM(以太坊虚拟机)执行。

compile

 这时候在目录/build/contracts下有两个文件,其中BatCoin.js就是上面合约编译的结果。

 migrate --reset //部署合约,--reset表示强制重新部署

 输出结果显示Migrations这个自带的合约已经部署成功,但是没有看到我们的BatCoin?仔细看下目录,发现在migrations里面有Migrations对应的脚本,很有可能是我们也需要建一个这样的脚本。

create migration deploy_batCoin

 执行以上命令,migrations目录出现了我们需要的文件,直接照着写就行

var batcoin = artifacts.require("./BatCoin.sol");
module.exports = function(deployer) {
    deployer.deploy(batcoin);
};

migrate --reset //部署合约,--reset表示强制重新部署

 这时候我们的合约也部署成功了,框住的就是合约的地址,到此合约的编写和部署就已经完成,BTW,部署合约也是需要支付一定的以太币的,因为其实这也属于一种交易的操作,任何交易都需要支付以太币,我们可以看下ganache的账户界面,发行以太币变少了



 truffle是一款强大的框架,掌握了以后可以大大提高我们的效率,后续许多功能官方持续更新中,下一篇我们介绍如何通过truffle调用合约、debug、还有单元测试...:)

上一篇 下一篇

猜你喜欢

热点阅读