web3j过滤器提供以太坊网络发生的某些事件的通知,对java和安卓程序员来说很有用。在Ethereum以太坊中支持三类过滤器:
- 块滤波器(Block filters)
- 未决交易过滤器(Pending transaction filters)
- 主题过滤器(Topic filters)
块过滤器和未决交易过滤器提供了在网络上创建新交易或块的通知。
主题过滤器更灵活。允许根据提供的特定标准创建过滤器。
不幸的是,除非你使用WebSocket连接到Geth,否则通过JSON-RPC API来处理过滤器是一个繁琐的过程,这里需要轮询以太坊客户端,以便了解HTTP和IPC所请求的实时同步特征,是否有任何新的更新到你的过滤器。此外,块和交易过滤器只提供交易或区块链hash值,因此需要进一步的请求来获得hash对应的实际交易或块。
web3j的过滤器解决了这些问题,因此你有一个完全异步的基于事件的API来处理过滤器。它使用RXJava的可观测性Observables,它提供了与事件协同工作的一致API,这有助于通过功能组合将JSON-RPC调用链接在一起。
注:Infura不支持过滤器。
块和交易过滤器
接收所有新块把它们添加到区块链(false参数指定我们只需要块就ok,而不需要嵌入交易):
Subscription subscription = web3j.blockObservable(false).subscribe(block -> {
...
});
接收所有新交易,把它们添加到块链:
Subscription subscription = web3j.transactionObservable().subscribe(tx -> {
...
});
接收所有待提交交易并提交到网络(即在它们被分组在一起之前):
Subscripti

本文详细介绍了web3j库中用于以太坊网络事件监听的过滤器功能,包括块过滤器、未决交易过滤器和主题过滤器,特别是如何通过主题过滤器捕获EVM事件。通过使用RXJava的Observables,web3j提供了一种异步、事件驱动的方式来处理过滤器,简化了与以太坊客户端的交互,并支持过滤器的组合操作。
最低0.47元/天 解锁文章
3242





