智能合约开发环境搭建及 Hello World 合约
如果你对于以太坊智能合约开发还没有概念(本文会假设你已经知道这些概念),建议先阅读入门篇。
就先学习任何编程语言一样,入门的第一个程序都是 Hello World。今天我们来一步一步从搭建以太坊智能合约开发环境开始,讲解智能合约的 Hello World 如何编写。
开发环境搭建
Solidity 安装
强烈建议新手使用Remix -Solidity IDE来进行开发。
Remix 是一个基于浏览器的Solidity,就可以不用安装 Solidity,本文的 Hello World 教程也将基于 Remix Solidity IDE 来进行。
如果你想自己安装请参考Solidity 安装指引。
更新,开发环境搭建还可以看另一篇文章:搭建智能合约开发环境 Remix IDE 及使用。
geth 安装
Mac 下安装命令如下:其他平台参考:geth 官方安装指引
brew 是 Mac 下的包管理工具,和 Ubuntu 里的 apt-get 类似
安装完以后,就是把 geth 控制台启动。
启动环境
在入门篇讲过,geth 是一个以太坊客户端,现在利用 geth启动一个以太坊(开发者)网络节点。
执行命名后,会进入 geth 控制台,这时光标停在一个向右的箭头处,像这样:
命令参数说明(更多命令详解可阅读Geth 命令用法 - 参数详解篇):
—dev启用开发者网络(模式),开发者网络会使用 POA 共识,默认预分配一个开发者账户并且会自动开启挖矿。
—datadir后面的参数是区块数据及秘钥存放目录。
第一次输入命令后,它会放在当前目录下新建一个 testNet 目录来存放数据。
console进入控制台
2>> test.log表示把控制台日志输出到 test.log 文件
为了更好的理解,建议新开一个命令行终端,实时显示日志:
准备账户
部署智能合约需要一个外部账户,我们先来看看分配的开发者账户,在控制台使用以下命令查看账户:
回车后,返回一个账户数组,里面有一个默认账户,如:
也可以使用 personal.listAccounts 查看账户,
再来看一下账户里的余额,使用以下命令:
eth.accounts[0]表示账户列表第一个账户
回车后,可以看到大量的余额,如:
1.15792089237316195423570985008687907853269… e+77
开发者账户因余额太多,如果用这个账户来部署合约时会无法看到余额变化,为了更好的体验完整的过程,这里选择创建一个新的账户。
创建账户
使用以下命令创建账户:
TinyXiong 为新账户的密码,回车后,返回一个新账户。
这时我们查看账户列表:
可以看到账户数组你包含两个账户,新账户在第二个(索引为 1)位置。
现在看看账户的余额:
回车后,返回的是 0,新账户是 0。结果如:
给新账户转账
我们知道没有余额的账户是没法部署合约的,那我们就从默认账户转 1 以太币给新账户,使用以下命令(请使用你自己 eth.accounts 对应输出的账户):
在打开的tail -f test.log日志终端里,可以同时看到挖矿记录
再次查看新账户余额,可以新账户有 1 个以太币
解锁账户
在部署合约前需要先解锁账户(就像银行转账要输入密码一样),使用以下命令:
“TinyXiong” 是之前创建账户时的密码
解锁成功后,账户就准备完毕啦,接下来就是编写合约代码。
编写合约代码
现在我们来开始编写第一个智能合约代码,solidity 代码如下:
简单解释下,我们定义了一个名为 hello 的合约,在合约初始化时保存了一个字符串(我们会传入 hello world),每次调用 say 返回字符串。
把这段代码写 (拷贝) 到Browser-Solidity,如果没有错误,点击 Details 获取部署代码,如:
在弹出的对话框中找到 WEB3DEPLOY 部分,点拷贝,粘贴到编辑器后,修改初始化字符串为 hello world。
solidity 在博文写作时(/11/24),版本为 0.4.18,solidity 发展非常快,solidity 版本之间有可能不能兼容,这是你可以在 Browser-Solidity 的 Settings 里选择对应的编译器版本。
Browser-Solidity 也不停的更新中,截图可能和你看到的界面不一样。
部署合约
Browser-Solidity 生成的代码,拷贝到编辑器里修改后的代码如下:
第 1 行:修改字符串为 Hello World
第 2 行:修改合约变量名
第 3 行:修改合约实例变量名,之后可以直接用实例调用函数。
第 6 行:修改部署账户为新账户索引,即使用新账户来部署合约。
第 8 行:准备付的 gas 费用,IDE 已经帮我们预估好了。
第 9 行:设置部署回调函数。
拷贝回 geth 控制台里,回车后,看到输出如:
说明合约已经部署成功。
在打开的tail -f test.log日志终端里,可以同时看到挖矿记录
现在我们查看下新账户的余额:
是不是比之前转账的余额少呀!
运行合约
输出 Hello World,我们第一个合约 Hello World,成功运行了。
运行截图如下:
本文会随 geth,solidity 语言版本升级保持更新,查看本文原始链接://11/24/init-env/