Hello world 是最简单的程序之一,也是大部分程序员编写的第一个程序。区块链入门也从最基础的Hello world智能合约开始。
在正式部署执行Hello world智能合约之前,我们需要在电脑上安装MetaMask for CMT。这是一个安装在Chrome 浏览器的钱包工具,它的主要功能是管理 CyberMiles 帐号私钥,实现从网页上直接支付 CMTs (包括gas 费)等功能。
安装过程比较简单,去官网https://www.cybermiles.io/metamask 下载插件,之后在Chrome的扩展程序中打开开发者模式,将下载好的 metamask4cmt.crx 拖拽至Chrome 的扩展程序页面。
拖拽后,如果Metamask for CMT 不能正常工作,可以试下重启浏览器。如果依然不能正常工作,可以试下下面的方法。
把下载好的metamask4cmt.crx 的后缀改成.rar,进行解压。在Chrome 扩展程序页面,点击 “加载已解压的扩展程序”,添加解压好的metamask4cmt.crx 就可以了。
此外,如果Chrome 中已经安装了其他版本的MetaMask,为了不影响使用,最好暂时停止使用其他版本的MetaMask,只留Metamask for CMT激活。
安装好MetaMask for CMT,就可以生成一个新的 CyberMiles 帐号来存储 CMTs,在最上方选择Main CyberMiles Network 或CMT Test Network。
MetaMask 需要有真实的CMT或者test CMT来支付执行智能合约的gas 费,分别对应主链状态、测试链状态。
CMT转账速度非常快,差不多10秒就到账了,并且不用支付gas费,转账体验+1分!
在 Chrome 里打开Remix for CMT,将写好的Hello World智能合约代码放进中间的代码编辑区,当然,你也可以选择自己写代码。
之后点击右侧的 Start to compile, 编译器会自动检查这段代码是否存在常规性错误。没有问题的话,编译器会自动识别出该段合约的名称,也就是 Contract 后面的Greet。如果有问题,编译器会给出提示,根据提示修改代码,再次编译即可。
检查代码没有问题后,就可以把Greet智能合约部署到 CyberMiles 区块链了。点击右侧最上方的Run,然后点击Deploy。这时需要调用MetaMask for CMT 支付部署智能合约所需要的gas 费。
一般情况下,MetaMask 的支付页面会自动跳出,点击 Submit 进行支付就可以了。如果没有自动跳出,手动点击插件就好了。可以看到,部署这个合约上链只需要花费0.000489个CMT。
支付完gas 费后,右下方Deployed Contracts 处就可以看到,我们的合约已经在CyberMiles 链上部署好了。
红色的terminate 可以终止这个合约,但只有合约owner 才可以执行这项操作,终止合约同样需要支持少量gas 费。
greet 显示智能合约的内容是什么,在这里是Hello World。当然,Hello World 这个词只是程序员的选择。作为智能合约的开发者,你可以让 greet() 返回任何字符 — 可以是一首歌,一篇文章,一本书,或者是一段加密的文字。
owner 显示这个合约的所有权归哪个地址所有。你为这个合约支付部署gas费的账号地址就是合约的所有者。
同时用区块浏览器www.cmttracking.io/查询交易地址信息,可以看到刚刚创建的合约地址。如果你的朋友有这个合约地址,在 At Address 栏内输入合约地址,点击At Address 就可以收到别致的智能合约问候啦!
我们上面看见怎么用Hello World智能合约在区块链存一段话,并让世界上任何人看见这段话。那么,这是怎么在代码里实现的呢?
pragma lity ^1.2.4;
复制代码
这是智能合约所用的代码语言及版本。
contract Greet {
function greet() {
}
function terminate() {
}
}
复制代码
以上代码介绍了智能合约的名字Greet,以及两个功能,greet和terminate。
address public owner;
modifier onlyOwner() {
assert(msg.sender == owner);
_;
}
constructor () public {
owner = msg.sender;
}
复制代码
以上的代码设置了合约的owner,owner的地址信息是公开的。信息发送者,也就是谁支付了gas费,让合约能够部署到链上,谁就是owner,并且定义了只有owner能够修改这个合约。
function greet() public pure returns (string) {
return "Hello world";
}
复制代码
以上代码表明当你调用greet()时,就会出现 Hello World。这个功能只是从区块链上读取数据,所以不需要 gas 费用。这里你可以把 Hello World 改成任何文字。
function terminate() external onlyOwner {
selfdestruct(owner);
}
复制代码
这就是智能合约最开始定义的terminate 终止合约的功能,并且定义了只有Owner可以执行这项功能。selfdestruct是析构函数,用于销毁数据,终止合约。
到这里,Hello World的代码就结束了,这是一段非常完整的代码。
这个最基础的合约既设置了合约的Owner,同时也设置了Owner 能够销毁合约,当执行selfdesruct时,合约里的钱也会返还给Owner。
因为合约地址与钱包地址长地非常像,并且长度也一致,如果不小心把币打到了合约地址,一般情况下,是无法找回的。但如果你知道合约的owner是谁,可以联系合约的owner,在销毁合约时拿回你的资产。
这只是个人的小损失,如果项目方没有认真地对待代码,带来的资产损失是非常严重的。非常典型的案例是,今年7月份,Polkadot 有超过513,774.16 ETH 被冻结在Parity钱包中,就是因为合约中的 owner 被人设成 null 了,因此没有人可以终止合约,拿回存在合约里的钱。现在,钱仍然被锁在合约里,永久冻结。
谨慎对待,认真审查每一段代码,尤其是涉及到钱的代码,这是每个程序员该有的素质。
CyberMiles 连最基础的智能合约代码也保证了代码的完整性,值得我们学习。
这是最简单最基础的Hello World,完整代码可去github查看。