Home > Backend Development > PHP Tutorial > PHP implements content parsing for interaction with Ethereum through JSON-RPC

PHP implements content parsing for interaction with Ethereum through JSON-RPC

不言
Release: 2023-04-03 21:52:01
Original
3069 people have browsed it

The content of this article is about the content analysis of PHP interacting with Ethereum through JSON-RPC. It has certain reference value. Friends in need can refer to it. I hope it will be helpful to you.

Since last year, we are developing blockchain (Blockchain) business. Having recently used Ethereum and working with PHP, I thought we'd chat about this topic.

There is a premise here:

  • 1. Understand the blockchain

  • 2. Have an understanding of programming languages

Text:

1. Development environment

We will use Ubuntu 14.04 LTS. After installing the operating system, enter the predetermined commands.

$ sudo apt-get update
$ sudo apt-get upgrade
Copy after login

After that I set up SSH, iptables, ntp, etc.

Then comes Apache PHP. The PHP version will be 5.5.

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

2. Introduction to Ethereum

This time we will use the Ethereum node made in GO language, go-ethereumreferred to as geth.

First let's add a repository.

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

After that, just install it.

$ sudo apt-get update
$ sudo apt-get install ethereum
Copy after login

Start geth immediately after the installation is completed.
First, create a data directory and describe the settings for the first block (the genesis block).

$ 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”:{}
}
Copy after login

Next, create the Genesis block and start 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
Copy after login

When in console mode, the startup is successful.

Specifies several options, the explanations are summarized below.

  • networkid, connect to public node.

  • port, it is a port used for standby. I changed it to 4 digits.

  • nodiscover, this is a setting that prevents nodes from automatically viewing.

  • datadir, specifies the directory where the blockchain stores data.

  • console, start the console at the same time.

Okay, let’s prepare for the next call to PHP, but before that let’s do a little more preparation on the geth side.

3. Prepare for JSON-RPC calls

Access from PHP via JSON-RPC. Here we will set up the neighborhood.

First, the current account information will be obtained. We also use the geth console we last started.

> eth.accounts
[]
Copy after login

We haven't created an account yet, so we need to create it.

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

Account now created. We set it up so that we can get rewards when mining.

> miner.setEtherbase(eth.accounts [0])
Copy after login

Next, since the current node does not allow RPC calls, add an option and start it again. First let's wrap up geth.

> exit
Copy after login

Let’s add options and restart

$ 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
Copy after login

Added several options for rpc. The explanation is as follows.

  • rpc, allows RPC backup.

  • rpcaddr, used for RPC backup IP address.

  • rpcport, the port used to listen to RPC. I lowered the port number to 4 digits.

  • rpccorsdomain, the domain that allows access to RPC. Note that when publishing a node, if it is "*" it will allow everything.

The node side is now ready. Next will be the call from PHP.

4. Access from PHP

The last thing is why access from PHP but have them because it is quite difficult to use this when you write code.

As you can see in the README, you only need to create a class.

Let's use it by placing it in the same directory as the test script.

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

require_once &#39;ethereum.php&#39;;
$ethereum = new Ethereum(&#39;localhost&#39;, &#39;8956&#39;);
print_r($ethereum->eth_accounts());
Copy after login

When we run this script, there should be a list of accounts as follows.

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

If you cannot connect, please check the port settings, etc.

So far, we have explained it simply, but does it feel like developing with PHP is surprisingly easy?

Related recommendations:

How the browser obtains relevant data through the JSON-RPC interface of the Bitcoin Core client

A simple json rpc framework example implemented in php

The above is the detailed content of PHP implements content parsing for interaction with Ethereum through JSON-RPC. For more information, please follow other related articles on the PHP Chinese website!

Related labels:
source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template