truffle - 介绍、编写和部署智能合约
truffle是一款为了方便开发、调试、部署智能合约的框架,他集成了很多功能,大大减少了开发的时间,官方把他比作一个以太坊的瑞士军刀,官网地址:http://truffleframework.com。
本系列文章将会介绍如何使用truffle框架对智能合约进行开发、调试、测试、部署。需要用到的工具有:
一、工具安装
1 .truffle
npm install -g truffle
-
ganache(巧克力酱)
ganache可以把他看做是你的节点服务,启动后节点服务随之启动,这样我们就不需要每次都通过控制台去启动节点,为了方便测试,系统会自动生成10个账户,而且每个账户里面有100个eth。
界面第一个tab(ACCOUNTS)显示的是节点里面的账号信息,其他根据名称也可以猜到:BLOCKS是每个区块的信息,TRANSACTIONS是交易信息,LOGS是日志。
最右边的设置项,可以设置节点的地址、网络id、端口、账户数、gas limit等。
ganache界面
配置界面
启动后,默认的地址是 http://127.0.0.1:7545,networkid:5777,我们就是用默认的就好,不需要改。
- 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、还有单元测试...:)