


Detaillierte Erläuterung der PHP-Beispiele für die Interaktion mit dem Ethereum-Client
Dieser Artikel informiert Sie über die relevanten Wissenspunkte zur Interaktion zwischen PHP- und Ethereum-Clients. Freunde, die dies benötigen, können folgen und 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 auf packagist.org gehen, um selbst 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. Angenommen, uint256 _value =. 437 76 für die Zwei Parameter, dann in Hexadezimal "0xab00" umwandeln, "0x" entfernen und Nullen zu 64 Bits hinzufügen. > von der Übertrageradressezur Vertragsadresse
Daten Die durch die obige Operation erhaltene Hexadezimalzahl
Konvertieren Sie die obigen Schritte in Code.
Erstellen eines Ethereum RPC-Clients
web3.sha3("transfer(address,uint256)").substring(0, 10)
The Code ist relativ einfach, es gibt ein paar Punkte zu beachten:
Übertragungsfunktion Die Werteinheit ist sehr klein, 10 ^ -18, also wenn Sie 1000 Mal übertragen möchten, Sie tatsächlich muss mit 10 multipliziert werden, erhöht auf die 18. Potenz.
-
Da Punkt 1, sollte bcpow anstelle der pow-Funktion verwendet werden 🎜>
Sie können die mit PHP gelieferte Dechex-Funktion nicht verwenden, da Dechex erfordert, dass der Ganzzahltyp nicht größer als PHP_INT_MAX sein darf und diese Zahl auf einem 32-Bit-Computer 4294967295 ist. Aufgrund von Punkt 1 müssen alle Zahlen mit 10 hoch 18 multipliziert werden, sodass die resultierende Zahl viel größer als PHP_INT_MAX ist. Es wird empfohlen, die Dezimalzahl selbst in Hexadezimalzahl umzuwandeln zum obigen Code. - Bei der Ausführung bestimmter Vertragsmethoden, wie z. B. der Überweisung, muss der Benutzer zuerst freigeschaltet werden
PHP cURL Holen Sie sich die Instanz von Öffentliches WeChat-Konto access_token PHP-Instanz
PHP implementiert den Karussell-Lotterie-Algorithmus zum Teilen von PHP-Beispielen
PHP verwendet curl_multi, um Beispiel-PHP-Fähigkeiten für gleichzeitige Anfragen zu implementieren
Das obige ist der detaillierte Inhalt vonDetaillierte Erläuterung der PHP-Beispiele für die Interaktion mit dem Ethereum-Client. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen

PHP 8.4 bringt mehrere neue Funktionen, Sicherheitsverbesserungen und Leistungsverbesserungen mit einer beträchtlichen Menge an veralteten und entfernten Funktionen. In dieser Anleitung wird erklärt, wie Sie PHP 8.4 installieren oder auf PHP 8.4 auf Ubuntu, Debian oder deren Derivaten aktualisieren. Obwohl es möglich ist, PHP aus dem Quellcode zu kompilieren, ist die Installation aus einem APT-Repository wie unten erläutert oft schneller und sicherer, da diese Repositorys in Zukunft die neuesten Fehlerbehebungen und Sicherheitsupdates bereitstellen.

Visual Studio Code, auch bekannt als VS Code, ist ein kostenloser Quellcode-Editor – oder eine integrierte Entwicklungsumgebung (IDE) –, die für alle gängigen Betriebssysteme verfügbar ist. Mit einer großen Sammlung von Erweiterungen für viele Programmiersprachen kann VS Code c

JWT ist ein offener Standard, der auf JSON basiert und zur sicheren Übertragung von Informationen zwischen Parteien verwendet wird, hauptsächlich für die Identitätsauthentifizierung und den Informationsaustausch. 1. JWT besteht aus drei Teilen: Header, Nutzlast und Signatur. 2. Das Arbeitsprinzip von JWT enthält drei Schritte: Generierung von JWT, Überprüfung von JWT und Parsingnayload. 3. Bei Verwendung von JWT zur Authentifizierung in PHP kann JWT generiert und überprüft werden, und die Funktionen und Berechtigungsinformationen der Benutzer können in die erweiterte Verwendung aufgenommen werden. 4. Häufige Fehler sind Signaturüberprüfungsfehler, Token -Ablauf und übergroße Nutzlast. Zu Debugging -Fähigkeiten gehört die Verwendung von Debugging -Tools und Protokollierung. 5. Leistungsoptimierung und Best Practices umfassen die Verwendung geeigneter Signaturalgorithmen, das Einstellen von Gültigkeitsperioden angemessen.

Dieses Tutorial zeigt, wie XML -Dokumente mit PHP effizient verarbeitet werden. XML (Extensible Markup-Sprache) ist eine vielseitige textbasierte Markup-Sprache, die sowohl für die Lesbarkeit des Menschen als auch für die Analyse von Maschinen entwickelt wurde. Es wird üblicherweise für die Datenspeicherung ein verwendet und wird häufig verwendet

Eine Zeichenfolge ist eine Folge von Zeichen, einschließlich Buchstaben, Zahlen und Symbolen. In diesem Tutorial wird lernen, wie Sie die Anzahl der Vokale in einer bestimmten Zeichenfolge in PHP unter Verwendung verschiedener Methoden berechnen. Die Vokale auf Englisch sind a, e, i, o, u und sie können Großbuchstaben oder Kleinbuchstaben sein. Was ist ein Vokal? Vokale sind alphabetische Zeichen, die eine spezifische Aussprache darstellen. Es gibt fünf Vokale in Englisch, einschließlich Großbuchstaben und Kleinbuchstaben: a, e, ich, o, u Beispiel 1 Eingabe: String = "TutorialPoint" Ausgabe: 6 erklären Die Vokale in der String "TutorialPoint" sind u, o, i, a, o, ich. Insgesamt gibt es 6 Yuan

Statische Bindung (statisch: :) implementiert die späte statische Bindung (LSB) in PHP, sodass das Aufrufen von Klassen in statischen Kontexten anstatt Klassen zu definieren. 1) Der Analyseprozess wird zur Laufzeit durchgeführt.

Was sind die magischen Methoden von PHP? Zu den magischen Methoden von PHP gehören: 1. \ _ \ _ Konstrukt, verwendet, um Objekte zu initialisieren; 2. \ _ \ _ Destruct, verwendet zur Reinigung von Ressourcen; 3. \ _ \ _ Call, behandeln Sie nicht existierende Methodenaufrufe; 4. \ _ \ _ GET, Implementieren Sie den dynamischen Attributzugriff; 5. \ _ \ _ Setzen Sie dynamische Attributeinstellungen. Diese Methoden werden in bestimmten Situationen automatisch aufgerufen, wodurch die Code -Flexibilität und -Effizienz verbessert werden.

In PHP können Sie CSRF -Angriffe effektiv verhindern, indem Sie unvorhersehbare Token verwenden. Spezifische Methoden umfassen: 1. CSRF -Token in der Form erzeugen und einbetten; 2. Überprüfen Sie die Gültigkeit des Tokens bei der Bearbeitung der Anfrage.
