PHP如何经过JSON-RPC与以太坊交互

自去年以来,咱们正在开发区块链(Blockchain)业务。最近使用过Ethereum并使用PHP,因此我想咱们应该聊聊这个话题。php

这里有个前提:git

  • 1.理解区块链
  • 2.对编程语言有了解

本文的主要内容:github

  • 1.开发环境
  • 2.以太坊的介绍
  • 3.准备JSON-RPC调用
  • 4.从PHP访问

1.开发环境

咱们将使用Ubuntu 14.04 LTS。安装操做系统后,输入预先肯定的命令。web

$ sudo apt-get update
$ sudo apt-get upgrade

以后我设置了SSH,iptables,ntp等等。apache

而后是Apache + PHP。PHP版本将为5.5。编程

$ sudo apt - get install php 5 libapache 2 - mod - php 5 php 5 - curl

2.以太坊的介绍

此次咱们将使用GO语言制做的以太坊节点,go-ethereum简称geth。json

首先让咱们添加一个存储库。vim

$ sudo apt-get install software-properties-common
$ sudo add-apt-repository -y ppa:ethereum / ethereum
$ sudo add-apt-repository -y ppa:ethereum / ethereum-dev

以后,只需安装它便可。api

$ sudo apt-get update
$ sudo apt-get install ethereum

安装完成后当即启动geth。
首先,建立一个数据目录并描述第一个块(创世块)的设置。cors

$ mkdir~ / eth_private_net
$ vim~ / eth_private_net / my_genesis.json

{
“nonce”:“0x0000000000000042”,
“timestamp”:“0x0”,
“parentHash”:“0x0000000000000000000000000000000000000000000000000000000000000000000000000000000000000000”,
“extraData”:“0x0”,
“gasLimit”:“0xffffffff”,
“难度”:“0x4000”,
“mixhash”:“0x000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000”,
“coinbase”:“0x3333333333333333333333333333333333333333”,
“alloc”:{}
}

接下来,建立Genesis块并启动geth。

$ geth --datadir "/home/yoshida/eth_private_net" init /home/yoshida/eth_private_net/my_genesis.json
$ geth --networkid 57598955 --port 8955 --nodiscover --datadir "/home/yoshida/eth_private_net" console 2>> /home/yoshida/eth_private_net/geth_err.log

处于控制台模式时,启动成功。

指定了几个选项,解释总结以下。

  • networkid,链接到公共节点。
  • port,它是一个用于待机的端口。我把它改成4位数字。
  • nodiscover,这是一个防止节点自动查看的设置。
  • datadir,指定区块链存储数据的目录。
  • console,在启动的同时启动控制台。

好了,准备PHP的下一个调用,可是在此以前让咱们在geth方面作更多准备。

3.准备JSON-RPC调用

经过JSON-RPC从PHP访问。在这里,咱们将设置邻域。

首先,将获取当前的账户信息。咱们还使用上次启动的geth控制台。

> eth.accounts
[]

咱们尚未建立一个账户,因此须要将建立它。

> personal.newAccount("password")
"0xb83fa0d1c6b34a42f900cca5a32400c3b6f69f4b"
> eth.accounts
["0xb83fa0d1c6b34a42f900cca5a32400c3b6f69f4b"]

账户现已建立。咱们设置它,以便在挖矿时能够得到奖励。

> miner.setEtherbase(eth.accounts [0])

接下来,因为当前节点不容许RPC调用,所以添加一个选项并再次启动它。首先让咱们结束geth。

> exit

让咱们添加选项并从新启动

$ geth --networkid 57598955 --port 8955 --nodiscover --rpc --rpcaddr "0.0.0.0" --rpcport "8956" --rpccorsdomain "*" --rpcapi "eth,net,web3,personal" --datadir "/home/yoshida/eth_private_net" console 2>> /home/yoshida/eth_private_net/geth_err.log

添加了rpc的几个选项。解释以下。

  • rpc,容许RPC备用。
  • rpcaddr,用于RPC备用的IP地址。
  • rpcport,用于监听RPC的端口。我将端口号下降为4位数。
  • rpccorsdomain,容许访问RPC的域。请注意,当发布节点时,若是它是“*”,它将容许全部内容。

节点端如今准备就绪。接下来将是来自PHP的调用。

4.从PHP访问

最后就是为何从PHP访问,而是有他们,由于这是至关困难,当你写代码的时候可使用这个

正如你在README中看到的,你只须要建立一个类。

让咱们经过将它放在与测试脚本相同的目录中来使用它。

$ cd /home/yoshida/php-eth/
$ ls -l
ethereum.php json-rpc.php
$ vim test.php
<?php

require_once 'ethereum.php';
$ethereum = new Ethereum('localhost', '8956');
print_r($ethereum->eth_accounts());

当咱们运行这个脚本时,应该有一个账户列表以下。

$ php test.php
Array
(
[0] => 0xb83fa0d1c6b34a42f900cca5a32400c3b6f69f4b
)

若是没法链接,请检查端口设置等。

到目前为止,咱们简单的解释了它,但感受使用PHP开发是否是出乎意料地容易?

当涉及智能合约时,它会变得有点复杂,咱们到时候再写一篇。

======================================================================

另外若是你想直接看看区块链在以太坊中是如何使用的,能够学习下面的教程:

php以太坊,主要是介绍使用php进行智能合约开发交互,进行帐号建立、交易、转帐、代币开发以及过滤器和事件等内容。

汇智网原创翻译,转载请标明出处。这里是原文

相关文章
相关标签/搜索