Dieser Artikel informiert Sie über die relevanten Wissenspunkte zur Interaktion zwischen PHP- und Ethereum-Clients. Freunde in Not können ihm folgen und daraus lernen.
php kommuniziert mit dem Ethereum-RPC-Server
1. Json RPC
Json RPC basiert Beim Remote-Prozeduraufruf von JSON ist diese Erklärung relativ abstrakt. Vereinfacht ausgedrückt bedeutet dies, Daten im JSON-Format zu veröffentlichen und die Methode auf dem RPC-Server aufzurufen. Im Allgemeinen sind die folgenden Elemente festgelegt:
{ "method": "", "params": [], "id": idNumber }
Methode: Methodenname
params: Parameterliste
id: eindeutige Kennung für die Prozeduraufruf Nr.
2. Erstellen Sie einen Json-RPC-Client
<?php class jsonRPCClient { /** * Debug state * * @var boolean */ private $debug; /** * The server URL * * @var string */ private $url; /** * The request id * * @var integer */ private $id; /** * If true, notifications are performed instead of requests * * @var boolean */ private $notification = false; /** * Takes the connection parameters * * @param string $url * @param boolean $debug */ public function __construct($url,$debug = false) { // server URL $this->url = $url; // proxy empty($proxy) ? $this->proxy = '' : $this->proxy = $proxy; // debug state empty($debug) ? $this->debug = false : $this->debug = true; // message id $this->id = 1; } /** * Sets the notification state of the object. In this state, notifications are performed, instead of requests. * * @param boolean $notification */ public function setRPCNotification($notification) { empty($notification) ? $this->notification = false : $this->notification = true; } /** * Performs a jsonRCP request and gets the results as an array * * @param string $method * @param array $params * @return array */ public function __call($method,$params) { // check if (!is_scalar($method)) { throw new Exception('Method name has no scalar value'); } // check if (is_array($params)) { // no keys $params = $params[0]; } else { throw new Exception('Params must be given as array'); } // sets notification or request task if ($this->notification) { $currentId = NULL; } else { $currentId = $this->id; } // prepares the request $request = array( 'method' => $method, 'params' => $params, 'id' => $currentId ); $request = json_encode($request); $this->debug && $this->debug.='***** Request *****'."\n".$request."\n".'***** End Of request *****'."\n\n"; // performs the HTTP POST $opts = array ('http' => array ( 'method' => 'POST', 'header' => 'Content-type: application/json', 'content' => $request )); $context = stream_context_create($opts); if ($fp = fopen($this->url, 'r', false, $context)) { $response = ''; while($row = fgets($fp)) { $response.= trim($row)."\n"; } $this->debug && $this->debug.='***** Server response *****'."\n".$response.'***** End of server response *****'."\n"; $response = json_decode($response,true); } else { throw new Exception('Unable to connect to '.$this->url); } // debug output if ($this->debug) { echo nl2br($debug); } // final checks and return if (!$this->notification) { // check if ($response['id'] != $currentId) { throw new Exception('Incorrect response id (request id: '.$currentId.', response id: '.$response['id'].')'); } if (!is_null($response['error'])) { throw new Exception('Request error: '. var_export($response['error'], true)); } return $response['result']; } else { return true; } } } ?>
Relativ einfach Code: Wenn Sie faul sind, nehmen Sie ihn einfach und verwenden Sie ihn. Sie können auch selbst auf packagist.org gehen, um einen RPC-Client zu finden.
3. Es gibt zwei Arten von Methoden zum Aufrufen von RPC Methoden, die aufgerufen werden müssen. Ein Typ ist die eigene Methode des RPC-Servers und der andere Typ ist die Vertragsmethode
RPC-Servermethode ruft das JSON-Format auf
{ "method": "eth_accounts", "params": [], "id": 1 }
RPC-Server-eigene Methode Die Liste der
ist relativ einfach, um die integrierte Methode aufzurufen, die meisten davon enthalten Beispiele Methodenaufruf-JSON-Format
Muss zum Aufrufen der Vertragsmethode eth_call in der integrierten Methode verwendet werden. Der Name der Vertragsmethode und die Parameterliste der Vertragsmethode werden mithilfe von Parametern wiedergegeben Rufen Sie die BalanceOf-Methode im Vertrag auf. Wie sollen die JSON-Daten aufgebaut sein? 🎜> Extrahieren Sie den Funktionsprototyp:function balanceOf(address _owner) public view returns (uint256 balance)
in geth. Führen Sie den Befehl unter der Konsole aus:
balanceOf(address)
Erhalten Sie den Funktions-Hash „0x70a08231“
Angenommen, die abzufragende Adresse ist Adresse _owner = „0x38aabef4cd283ccd5091298dedc88d27c5ec5750“, Regel Entfernen Sie das „0x“ vor und fügen Sie links 24 Nullen hinzu (das Allgemeine). Die Adresslänge beträgt 42 Bit und beträgt nach dem Entfernen von „0x“ 40 Bit, um einen 64-Bit-Hexadezimalparameter zu bilden.
Das Endergebnis ist „0x70a08231000000000000000000000038aabef4cd283ccd5091298dedc88d27c5ec57“. 50"
Angenommen, unser Die Vertragsadresse lautet „0xaeab4084194B2a425096fb583Fbcd6 7385210ac3“.
dann lauten die endgültigen JSON-Daten:
web3.sha3("balanceOf(address)").substring(0, 10)
Senden Sie die oben genannten JSON-Daten per Post an den Server Modus, dann können Sie die Vertragsmethode „balanceOf“ aufrufen, um den Token-Saldo in der angegebenen Adresse abzufragen.
Der Aufruf anderer Methoden im Vertrag muss ebenfalls neu sein. Analysieren wir nach der obigen Methode die Übertragungsmethode erneut Vertiefen Sie unseren Eindruck:
Schauen Sie sich zunächst die Funktionsimplementierung im Code an:
{ "method": "eth_call", "params": [{"from": "0x38aabef4cd283ccd5091298dedc88d27c5ec5750", "to": "0xaeab4084194B2a425096fb583Fbcd67385210ac3", "data": "0x70a0823100000000000000000000000038aabef4cd283ccd5091298dedc88d27c5ec5750"}, "latest"], "id": 1 }
Zweitens extrahieren Sie den Funktionsprototyp:
function transfer(address _to, uint256 _value) public returns (bool)
Führen Sie erneut die sha3-Funktion auf der Konsole aus:
transfer(address,uint256) //注意逗号后面不能有空格
Holen Sie sich den Funktions-Hash " 0xa9059cbb"
Der erste Parameter geht von der Adresse _to = "0x38aabef4cd283ccd5091298dedc88d27c5ec5750" aus, dann gehe zu "0x" und füge Nullen zu 64 Bits hinzu.
Nein. Vorausgesetzt, dass uint256 _value =. 43 776, Die beiden Parameter werden in hexadezimal „0xab00“ konvertiert, dann wird „0x“ entfernt und Nullen werden zu 64 Bits hinzugefügt 🎜>JSON-Daten erstellen:
web3.sha3("transfer(address,uint256)").substring(0, 10)
von der Übertrageradresse
{ "method": "eth_call", "params": [{"from": "0x38aabef4cd283ccd5091298dedc88d27c5ec5750", "to": "0xaeab4084194B2a425096fb583Fbcd67385210ac3", "data": "0xa9059cbb00000000000000000000000038aabef4cd283ccd5091298dedc88d27c5ec5750000000000000000000000000000000000000000000000000000000000000ab00"}, "latest"], "id": 1 }
Das obige ist der detaillierte Inhalt vonDetaillierte Erläuterung der Interaktion zwischen PHP und Ethereum-Client. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!