本文节选自图书《区块链开发指南》,本书由 申屠青春 主编,宋波、张鹏、汪晓明、季宙栋、左川民 联合编著。
区块链相关约稿、文章纠错、寻求报道等可邮件联系 jiawd@csdn.net
如何部署、调用智能合约
RPC
之前的章节中讲到了怎么写、部署合约以及与合约互动。现在该讲讲与以太坊网络和智能合约沟通的细节了。
一个以太坊节点提供一个RPC界面。这个界面给Ðapp(去中心化应用)访问以太坊区块链的权限和节点提供的功能,比如编译智能合约代码,它用JSON-RPC 2.0规范(不支持提醒和命名的参数) 的子集作为序列化协议,在HTTP和IPC (linux/OSX上的unix域接口,在Windows上叫pipe’s)上可用。
惯例
RPC界面会使用一些惯例,但它们不是JSON-RPC 2.0规范的一部分,这些惯例如下:
数字是十六进制编码。做这个决定是因为有些语言对运行极大的数字没有或有很少的限制。为了防止这些错误数字类型是十六进制编码,由开发者来分析这些数字并正确处理它们。在维基页百科查看十六进制编码章节查看案例。
默认区块数字。几个RPC 方法接受区块数字。在一些情况下,给出区块数字是不可能的或者不太方便。在那样的情况下,默认区块数字可以是以下字符串中的一个[”earliest”, “latest”, “pending”]。在维基页面可查看使用默认区块参数的RPC方法列表。
部署合约
我们会通过不同的步骤来部署下面的合约,但只用到RPC界面。
contract Multiply7 {
event Print(uint);
function multiply(uint input) returns (uint) {
Print(input
*
7);
return input
*
7;
}
}
要做的第一件事是确保HTTP RPC界面可用。这意味着我们在开始为geth供应—rpc标志,为eth提供-j标志。在这个例子中,用的是私有开发链上的geth节点。通过这种方法,我们就不需要真实网络上的以太币了。
\> geth --rpc --dev --mine --minerthreads 1 --unlock 0 console 2>>geth.log
这会在http://localhost:8545上启动HTTP RPC界面。
注意:geth支持CORS查看—rpccorsdomain标志了解更多。
我们可以通过用curl检索coinbase地址和余额来证明界面正在运行。请注意这些例子中的数据在你本地的节点上会有所不同。如果你想要试试这些参数,视情况替换需要的参数。
\> curl --data '{"jsonrpc":"2.0","method":"eth_coinbase", "id":1}' localhost:8545
{
"id":1,"jsonrpc":"2.0","result":["0xeb85a5557e5bdc18ee1934a89d8bb402398ee26a"]}
> curl --data '{"jsonrpc":"2.0","method":"eth_getBalance", "params": ["0xeb85a5557e5bdc18ee1934a89d8bb402398ee26a"], "id":2}' localhost:8545
{
"id":2,"jsonrpc":"2.0","result":"0x1639e49bba16280000"}
记不记得前面说过数字是十六进制编码?在这个情况下,余额作为十六进制字符串以Wei的形式返还。如果希望余额作为数字以太币为单位,可以从控制台用web3,示例如下:
\> web3<