PHP 如何透過 JSON-RPC 呼叫實現以太坊互動

geeker發表於2018-08-23

自去年以來,我們正在開發區塊鏈(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進行智慧合約開發互動,進行賬號建立、交易、轉賬、代幣開發以及過濾器和事件等內容。

本作品採用《CC 協議》,轉載必須註明作者和本文連結

相關文章