参考: https://yq.aliyun.com/articles/212944#2
目标
1. 了解智能合约
2. 简单环境搭建
3. 能够利用solidity编写Hello World合约
4. 合约部署
5. 与合约互动
开发前的准备
truffle:最活跃的智能合约开发框架。
就像一般网站或App开发一样,在提供公开服务之前,开发者会在自己用于写程序的电脑(又称作本机)或透过测试网络来测试程序执行的效果,测试完成后,才会部署到公开的网络上提供服务。
开发区块链智能合约(程序)的过程也是如此。特别是公开链上所有写入或读取计算结果的操作都需要真金白银(虚拟代币),而且根据网络状况,每个公开链上的操作都需要要一小段反应时间(15秒~数分钟),这些等待颇浪费宝贵的开发时间⏳。
因此在开发的过程中,我们将使用testrpc工具在电脑上模拟智能合约所需的以太坊内存块链测试环境。
testrpc中也包含了Javascript版本的Ethereum虚拟机(Ethereum Virtual Machine),因此可以完整地执行智能合约。
安装所需工具
首先开发机上必须装好Node.js,再使用以下命令安装所需的工具:
$ npm install -g ethereumjs-testrpc truffle
启动Testrpc
安装好后随时可以使用testrpc命令来启动以太坊测试环境。
testrpc启动后自动建立了10个帐号(Accounts),与每个帐号对应的私钥(Private Key)。每个帐号中都有100个测试用的以太币(Ether)。
建立项目
开启另一个终端窗口,输入以下命令以建立项目:
richard@Rich:~/eth/SmartContractDemo$ ls
HelloWorld
richard@Rich:~/eth/SmartContractDemo$ cd HelloWorld/
richard@Rich:~/eth/SmartContractDemo/HelloWorld$ truffle init (第一条命令)
Downloading...
Unpacking...
Setting up...
Unbox successful. Sweet!
Commands:
Compile: truffle compile
Migrate: truffle migrate
Test contracts: truffle test
richard@Rich:~/eth/SmartContractDemo/HelloWorld$ ls
contracts migrations test truffle-config.js truffle.js
richard@Rich:~/eth/SmartContractDemo/HelloWorld$
目录结构
/contracts:存放智能合约原始代码的地方,可以看到里面已经有三个sol文件,我们开发的HelloWorld.sol文件就存放在这里。
/migrations:这是Truffle用来部署智能合约的功能,待会儿我们会修改2_deploy_contracts.js来部署HelloWorld.sol。
/test: 测试智能合约的代码放在这里,支持js与sol测试。
truffle.js:Truffle的设置文档。
编译
现在执行truffle compile(第二条命令)命令,我们可以将HelloWorld.sol原始码编译成Ethereum bytecode
部署
truffle框架中提供了方便部署合约的脚本。打开migrations/2_deploy_contracts.js文件(脚本使用Javascript编写),将内容修改如下:
varHelloWorld = artifacts.require("HelloWorld");
module.exports =function(deployer){
deployer.deploy(HelloWorld);
};
用artifacts.require语句来取得准备部署的合约。使用deployer.deploy语句将合约部署到区块链上。
这边HelloWorld是contract的名称而不是文件名。
因此可以用此语法读入任一.sol文件中的任一合约。
现在执行truffle migrate(第三条命令)命令:
小插曲:
在使用truffle migrate进行智能合约test环境发布时如果未配置正确会出现以下异常:
导致上面异常的原因为是因为truffle.js里面未配置链接合约发布的环境地址,找到对应的truffle.js文件,修改代码为类似如下配置即可解决问题:
修改后,继续运行
合约已经部署到testrpc中。切换到testrpc窗口,可以看到testrpc有反应了。
与合约互动
truffle提供命令行工具,执行truffle console命令后,可用Javascript来和部署的合约互动。
HelloWorld.deployed().then(instance => contract = instance)
truffle console中预载了truffle-contract函数库,以方便操作部署到区块链上的合约。
这边使用HelloWorld.deployed().then语句来取得HelloWorld合约的Instance(实例),并存到contract变量中,以方便后续的调用
contract.sayHello.call()
truffle-contract提供使用call()来读取只读(read only)的数据,这样就不需提供gas。因此如果遇到的操作需要向区块链写入数据,我们就不能用call语句了。
如此一来,我们已写好并部署完成了第一个智能合约,也验证了合约确实可以运作。