iamirnet/ethereum-php

一个将以太坊与类型化PHP集成的库。

dev-master 2024-09-24 16:08 UTC

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.jsonDrupal 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

请参阅UsingFiltersethereum-php-eventlistener

限制

目前不支持所有数据类型。

这个库目前是只读的。这意味着您可以检索存储在以太坊区块链中的信息。

要写入区块链,需要使用私钥对交易进行签名,但目前尚不支持。

architecture diagram

文档

API文档可在ethereum-php.org找到。

参考Ethereum RPC文档以及RLP文档,在Ethereum Wiki中查看数据编码。

还有一个更易于阅读的Ethereum Frontier指南版本。