跳到主要内容

EVM

OpenBlock DappSDK 会生成全局变量 window.openblock 注入您的网站中。

集成 DappSDK

    // 建议在html文档中尽量靠前放置,加快初始化过程
// 建议直接引用下面的cdn链接方便即时更新SDK,不推荐开发者将此js文件下载到自己的服务器使用
<div>
<button id="sendETHButton">Send ETH</button>
</div>
<script type="text/javascript" charset="UTF-8" src="https://obstatic.243096.com/download/dapp/sdk/index.js">
</script>
<script type="text/javascript">=
const sendETHButton = document.getElementById('sendETHButton');
sendETHButton.onclick = async () => {
const result = await openblock.request({
method: 'eth_sendTransaction',
params: [
{
from: accounts[0],
to: '0xEC4fD89cf3aCf436Fe3be0310C3caa5834A04FE4',
value: '0x0',
gasLimit: '0x5028',
gasPrice: '0x2540be400',
type: '0x0',
},
],
});
console.log(result);
};
</script>
提示
  1. 仅使用 openblock 钱包,屏蔽其他插件钱包,例如:可以直接将 metamask 插件注入的全局变量 window.ethereum 替换为 window.openblock:

       window.ethereum = window.openblock;
  2. openblock 钱包和其他插件钱包共存,可以在切换钱包的时候创建新的 provider 对象,避免使用赋值操作对 openblock 或者 ethereum 污染:

       let provider = Object.create(window.openblock);
    const OpenblockWallet = document.getElementById('OpenblockWallet');
    const MetaMaskWallet = document.getElementById('MetaMaskWallet');
    OpenblockWallet.onclick = async () => {
    provider = Object.create(window.openblock);
    ethersProvider = new ethers.providers.Web3Provider(provider, 'any');
    };
    MetaMaskWallet.onclick = async () => {
    if (window.ethereum) {
    provider = Object.create(window.ethereum);
    }
    ethersProvider = new ethers.providers.Web3Provider(provider, 'any');
    };
    const accounts = await provider.request({
    method: 'eth_requestAccounts',
    });

sdkLoaded

    const sdkLoaded = window.openblock.sdkLoaded;

version

    const version = window.openblock.version;

OpenBlock RPC API Methods

net_version

Returns the network ID associated with the current network.

  • Result: Network ID associated with the current network.
title:networkId
type:string
  • Examples:

    request:

    {
    id: 1,
    method: "net_version "
    }

    response:

    {
    id: 1,
    result: "1"
    }

eth_chainId

Returns the currently configured chain id, a value used in replay-protected transaction signing as introduced by EIP-155.

  • Result: hex format integer of the current chain id.
title:chainId
type:string
  • Examples:

    request:

    {
    id: 0,
    method: "eth_chainId "
    }

    response:

    {
    "id": 0,
    "result": "0x1",
    }

eth_getBlockByNumber

Gets a block for a given number

  • Params:
Parameter NameSummarytypeRequired
blockNumberblockNumber/blockNumberTagstringtrue
includeTransactionsIf true it returns the full transaction objects, if false only the hashes of the transactions.booleantrue
  • Result: hex format integer of the current chain id.
type:object
  • Examples:

    request:


    {
    "method": "eth_getBlockByNumber",
    "params": ["latest",false],
    "id": 0
    }

    response:

    {
    "result": {
    "baseFeePerGas": "0x4a5418aba",
    "difficulty": "0x2f2e440990cb01",
    "extraData": "0x4b75436f696e506f6f6c21ad7e9019ea55b4aa",
    "gasLimit": "0x1c9c364",
    "gasUsed": "0x4638a1",
    "hash": "0x10be226bf192ab42155db0a0e946533fda9113b141f81dea915fd95da547d81d",
    "logsBloom": "0x2c282036744004824045898a80182228000a0000008001009890008210cb000260040800008808844908220020104105422048820a4418802a542d8a02390704281060374016180008005208025100a8820806481090603025000141e2c0048800048042c282300000a00140118098322031181080020442101114101090810028069010222e020140088402210823c50100240901200058006000d0005024029a00261f08813080009ae0800a0000400510004100000a820501042540c800004119c00e010a0ec02c080120007401d0006112c20317201400110900004a200000196020152308858198040890004d89412000042808885600000b8020202008",
    "miner": "0xd757fd54b273bb1234d4d9993f27699d28d0edd2",
    "mixHash": "0xd9746f14bdc78c7cfc1b0a7b63415f4ed9a9e5ad362abd18095f433c17cc1851",
    "nonce": "0xa5f534cb95eb17db",
    "number": "0xe4c1c3",
    "parentHash": "0xd9d8e92dc738abc931e812a9f04f8053d9bd5c6f33ac48a6d40bee4b394619ff",
    "receiptsRoot": "0xa56de219bd79cbab4b5d9ac91f4effb03c29f3796f472261e0e3a76558771fb0",
    "sha3Uncles": "0x1dcc4de8dec75d7aab85b567b6ccd41ad312451b948a7413f0a142fd40d49347",
    "size": "0x46cb",
    "stateRoot": "0x9b8db6e9bf2be2459e5417b8264f7dd2b8e76336f2abedaab2c6125fc597eaf6",
    "timestamp": "0x62af5421",
    "totalDifficulty": "0xb083fd230e5ddc3f495",
    "transactions": [
    "0x2fc199d50601ef95b7048f5301eea3f54c0ad0f5bc735dabf35127af1c90adf3",
    ],
    "transactionsRoot": "0x4b2bfa207d13e692f83dea70031f7f0bb6c6b93f5824be91a6118ac6daf63fa9",
    "uncles": []
    },
    "id": 0
    }

eth_requestAccounts

Returns an array of a single, hexadecimal Ethereum address string.

  • Examples:

    request:

    {
    id: 1,
    method: "eth_requestAccounts"
    }

    response:

    {
    id: 1,
    result: ["0xa6384d65b40afe4b3ad44c49fa65b55988109997"]
    }

eth_accounts

Returns an array of a single, hexadecimal Ethereum address string.

  • Examples:

    request:

    {
    id: 1,
    method: "eth_accounts"
    }

    response:

    {
    id: 1,
    result: ["0xa6384d65b40afe4b3ad44c49fa65b55988109997"]
    }

eth_sendTransaction

Creates new message call transaction or a contract creation, if the data field contains code.

  • Params:
Parameter NameSummarytypeRequired
transactionobjecttrue
  • Examples:

    request:

    {
    id: 1,
    "method": "eth_sendTransaction",
    "params": [
    {
    from: accounts[0],
    to: '0x0c54FcCd2e384b4BB6f2E405Bf5Cbc15a017AaFb',
    value: '0x0',
    gasLimit: '0x5028',
    gasPrice: '0x2540be400',
    type: '0x0',
    },
    ],
    }

    response:

    {
    id: 1,
    result: "0x8f8f2a230c9a4a49d4a78105ca2d7152496463673ddc3200aa43344818087717"
    }

eth_estimateGas

Generates and returns an estimate of how much gas is necessary to allow the transaction to complete. The transaction will not be added to the blockchain. Note that the estimate may be significantly more than the amount of gas actually used by the transaction, for a variety of reasons including EVM mechanics and node performance.

  • Params:
Parameter NameSummarytypeRequired
transactionobjecttrue
  • Examples:

    request:

    {
    id: 1,
    "method": "eth_sendTransaction",
    "params": [
    {
    data: "0x5ae401dc",
    from: "0xe2101f6b5fe0855f7e5809766fcc2e6a985c2f00",
    to: "0x68b3465833fb72a70ecdf485e0e4c7bd8665fc45",
    value: "0x46651311744350",
    },
    ],
    }

    response:

    {
    id: 1,
    result: "0x25a48",
    }

eth_getTransactionReceipt

Returns the receipt information of a transaction by its hash.

  • Params:
Parameter NameSummarytypeRequired
transactionHashKeccak 256 Hash of the RLP encoding of a transactionstringtrue
  • Examples:

    request:

    ```js
    {
    id: 1,
    method: "eth_getTransactionReceipt",
    params: ['0x5151e5ba317753cdbbfab896f3eabdb01e3577f78d37398578198cf01ac6278e']
    }
    ```

    response:

    ```js
    {
    id: 1,
    result: {
    blockHash: "0xa59b17ecfe56635063b7d0427b528810bbf2f2886587b087e8f4cebf6a255f1b",
    blockNumber: "0xbda3c8",
    contractAddress: null,
    cumulativeGasUsed: "0x15e623",
    effectiveGasPrice: "0x3b9aca07",
    from: "0xe2101f6b5fe0855f7e5809766fcc2e6a985c2f00",
    gasUsed: "0x1f9fc",
    logs: (4) [{…}, {…}, {…}, {…}],
    logsBloom: ,"0x00000000000000000000000000000000000000004000000000000000000000400000000000000000000000200000001000000000000020000000000000000000040000000000000800000008100000008000000000000000000000008000000008000000000000000000000000000000000000000000000000000010000800000000000000000000000800000010000000000001000000000000000000000000000000000000100000000000000200000000000000000000000004000000000000000002000000000000000000000000000000000000000000001100000000000000200000000000000000000000080000002000000000400000000000000000",
    status: "0x1",
    to: "0x68b3465833fb72a70ecdf485e0e4c7bd8665fc45",
    transactionHash: "0x5151e5ba317753cdbbfab896f3eabdb01e3577f78d37398578198cf01ac6278e",
    transactionIndex: "0x11",
    type: "0x2"
    },
    }

    ```

eth_getTransactionByHash

Returns the information about a transaction requested by transaction hash.

  • Params:
Parameter NameSummarytypeRequired
transactionHashKeccak 256 Hash of the RLP encoding of a transactionstringtrue

eth_sign

  • Examples

    request:

    {
    id: 1,
    "method":"eth_sign"
    "params":[accounts[0], '0x879a053d4800c6354e76c7985a865d2922c82fb5b3f4577b2fe08b998954f2e0']
    }

    response:

    {
    id: 1,
    "result":'',
    }

personal_sign

Presents a plain text signature challenge to the user.

  • Params:
Parameter NameSummarytypeRequired
ChallengeA hex-encoded UTF-8 string to present to the user. You can see how to encode a string like this in the module browser-string-hexer.stringtrue
AddressThe address of the requested signing account.stringtrue
  • Examples

    request:

    const from = accounts[0];
    const msg = `0x${Buffer.from(exampleMessage, 'utf8').toString('hex')}`;
    {
    id: 1,
    "method":"personal_sign"
    "params":[msg, from]
    }

    response:

    {
    id: 1,
    "result":'',
    }

wallet_switchEthereumChain

Creates a confirmation asking the user to switch to the chain with the specified chainId.

  • Examples

    request:

    {
    id: 1,
    "method":"wallet_switchEthereumChain"
    "params":[
    {
    chainId: "0x64",
    },
    ]
    }

    response:

    {
    id: 1,
    "result":null,
    }