我正在寻找一种方法来获取给定地址的交易列表。如果交易太多,我希望能够对结果进行分页。如果我可以将最新处理的交易作为参数提供,这样我就可以从给定点获取最新交易会更好。
像这样的东西:
var page = 1;
txList = getTransactionList("0x323432432...", page, lastProcessedTx);
我正在寻找一种方法来获取给定地址的交易列表。如果交易太多,我希望能够对结果进行分页。如果我可以将最新处理的交易作为参数提供,这样我就可以从给定点获取最新交易会更好。
像这样的东西:
var page = 1;
txList = getTransactionList("0x323432432...", page, lastProcessedTx);
从我目前的研究来看,没有办法获得地址的交易列表。您应该检查给定地址的区块链中的所有交易,或将地址与数据库中的交易哈希相关联。请参阅确认缺少所需 API 的线程: https ://github.com/ethereum/go-ethereum/issues/1897
另一种方法是使用 Etherscan API:https ://etherscan.io/apis 但它取决于第三方服务器。
已知的以太坊节点缺乏获取 ETH 地址(账户)交易列表的功能。
为了解决这个问题,有免费和开源的第三方解决方案——以太坊交易索引器:https ://github.com/Adamant-im/ETH-transactions-storage
索引器允许通过以太坊地址探索交易,并像 Etherscan 一样,只需一步即可获得任何用户|钱包的历史记录。索引器是用 Python 编写的。它在后台作为服务工作:
Indexer 连接到以太坊节点并使用 JSON RPC 获取交易,在 Postgres 数据库中创建交易索引。第一个索引器将从您指定的块开始存储交易。之后,它将每 20 秒检查一次新块并更新索引。您可以更改间隔。
以太坊交易索引器的 API 由 Postgrest 工具发布。如果您需要提供公共 API,请使用任何网络服务器(如 nginx)并在配置中为 Postgrest 端口设置代理。
创建索引后,您可以使用请求
curl -k -X GET "http://localhost:3000/?and=(contract_to.eq.,or(txfrom.eq.0x6b924750e56a674a2ad01fbf09c7c9012f16f094,txto.eq.0x6b924750e56a674a2ad01fbf09c7c9012f16f094))&order=time.desc&limit=25"
或者
https://yourserver.com/ethtxs?and=(contract_to.eq.,or(txfrom.eq.0x6b924750e56a674a2ad01fbf09c7c9012f16f094,txto.eq.0x6b924750e56a674a2ad01fbf09c7c9012f16f094))&order=time.desc&limit=25
该请求将显示以太坊地址 0x6b924750e56a674a2ad01fbf09c7c9012f16f094 的 25 个最后交易,按时间戳排序。
可能你现在最好的选择是使用https://www.covalenthq.com/docs/api/
据我所知,它可以免费使用,没有速率限制。在您的情况下,示例 API 请求如下所示:
curl -X GET "https://api.covalenthq.com/v1/1/address/0x5a6d3b6bf795a3160dc7c139dee9f60ce0f00cae/transactions_v2/?&key=[YOUR_API_KEY]" \
-H "Accept: application/json"
https://www.covalenthq.com/docs/api/#get-/v1/{chain_id}/address/{address}/transfers_v2/
您可以使用 etherscan.io API:https ://etherscan.io/apis#accounts 示例
幸运的是,Geth EVM 有新工具可以完成这项工作。可以将 debug_traceTransaction 与 RPC API 一起使用。
在 NodeJS 中:
var web3 = require('web3').web3;
web3.currentProvider.sendAsync({
method: "debug_traceTransaction",
params: ['0x3fac854179691e377fc1aa180b71a4033b6bb3bde2a7ef00bc8e78f849ad356e', {}],
jsonrpc: "2.0",
id: "2"
}, function (err, result) {
...
});
然后,您需要“CREATE”、“CALL”、“CALLCODE”和“DELEGATECALL”操作码并跟踪堆栈。