iamirnet / ethereum-php
一个将以太坊与类型化PHP集成的库。
dev-master
2024-09-24 16:08 UTC
Requires
- digitaldonkey/ecverify: 1.0
- graze/guzzle-jsonrpc: ~3.0
- kornrunner/keccak: ^1.0
- pear/math_biginteger: ^1.0
Requires (Dev)
- gossi/php-code-generator: ^0.5.0
This package is auto-updated.
Last update: 2024-09-24 16:09:40 UTC
README
是PHP 7.1+的以太坊JSON-RPC API的类型化接口。
查看最新的API文档。
在composer.json文件中添加库
{ "minimum-stability":"dev", "autoload": { "psr-4": { "Ethereum\\": "src/" } }, "repositories": [ { "type": "git", "url": "https://github.com/digitaldonkey/ethereum-php.git" } ], "require": { "digitaldonkey/ethereum-php": "dev-master" } }
用法
composer require digitaldonkey/ethereum-php
这是composer.json在Drupal Ethereum模块中的重要部分。
require __DIR__ . '/vendor/autoload.php'; use Ethereum\Ethereum; try { // Connect to Ganache $eth = new Ethereum('http://127.0.0.1:7545'); // Should return Int 63 echo $eth->eth_protocolVersion()->val(); } catch (\Exception $exception) { die ("Unable to connect."); }
调用合约
您可以轻松调用智能合约中的(未付费)函数。
使用的json文件"$fileName"是在使用Truffle编译合约时获得的。
$ContractMeta = json_decode(file_get_contents($fileName)); $contract = new SmartContract( $ContractMeta->abi, $ContractMeta->networks->{NETWORK_ID}->address, new Ethereum(SERVER_URL) ); $someBytes = new EthBytes('34537ce3a455db6b') $x = $contract->myContractMethod(); echo $x->val()
您还可以在智能合约中运行测试,查看EthTestClient。
事件监听和处理
您可以使用Ethereum-PHP来监视您的智能合约的变化或逐块索引区块链。gs
请参阅UsingFilters和ethereum-php-eventlistener。
限制
目前不支持所有数据类型。
这个库目前是只读的。这意味着您可以检索存储在以太坊区块链中的信息。
要写入区块链,需要使用私钥对交易进行签名,但目前尚不支持。
文档
API文档可在ethereum-php.org找到。
参考Ethereum RPC文档以及RLP文档,在Ethereum Wiki中查看数据编码。
还有一个更易于阅读的Ethereum Frontier指南版本。