PHP与以太坊交互详解
作者:以太坊
自去年以来,我们正在开发区块链(Blockchain)业务。最近使用过Ethereum并使用PHP,所以我想我们应该聊聊这个话题。
这里有个前提:
1.理解区块链
2.对编程语言有了解
本文的主要内容:
1.开发环境
2.以太坊的介绍
3.准备JSON-RPC调用
4.从PHP访问
1.开发环境
我们将使用Ubuntu 14.04 LTS。安装操作系统后,输入预先确定的命令。
$ sudo apt-get update $ sudo apt-get upgrade
之后我设置了SSH,iptables,ntp等等。
然后是Apache + PHP。PHP版本将为5.5。
$ sudo apt - get install php 5 libapache 2 - mod - php 5 php 5 - curl
2.以太坊的介绍
这次我们将使用GO语言制作的以太坊节点,go-ethereum简称geth。
首先让我们添加一个存储库。
$ sudo apt-get install software-properties-common $ sudo add-apt-repository -y ppa:ethereum / ethereum $ sudo add-apt-repository -y ppa:ethereum / ethereum-dev
之后,只需安装它即可。
$ sudo apt-get update $ sudo apt-get install ethereum
安装完成后立即启动geth。 首先,创建一个数据目录并描述第一个块(创世块)的设置。
$ 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进行智能合约开发交互,进行账号创建、交易、转账、代币开发以及过滤器和事件等内容。