自去年以來,我們正在開發區塊鏈(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 協議》,轉載必須註明作者和本文連結