Project Icon

rust-web3

Rust实现的以太坊Web3客户端库

rust-web3是Rust语言实现的以太坊JSON-RPC客户端库,支持HTTP、IPC和WebSocket传输。它提供了丰富的API,包括eth、net和web3等命名空间,支持合约调用、批量请求和自定义扩展。该库为Rust开发者提供了与以太坊区块链交互的完整工具集。

web3

以太坊JSON-RPC多传输客户端。 Web3.js库的Rust实现。

构建状态 Crates.io

文档: crates.io

状态

请注意,这个包几乎不再维护,我正在寻找一位积极的维护者(参见 #664)。 如果你正在开始一个新项目,我建议选择 https://github.com/gakonst/ethers-rs

使用方法

首先,在你的 Cargo.toml 中添加以下内容:

[dependencies]
web3 = "0.19.0"

示例

#[tokio::main]
async fn main() -> web3::Result<()> {
    let transport = web3::transports::Http::new("http://localhost:8545")?;
    let web3 = web3::Web3::new(transport);

    println!("调用账户。");
    let mut accounts = web3.eth().accounts().await?;
    println!("账户: {:?}", accounts);
    accounts.push("00a329c0648769a73afac7f9381e08fb43dbea72".parse().unwrap());

    println!("调用余额。");
    for account in accounts {
        let balance = web3.eth().balance(account, None).await?;
        println!("{:?} 的余额: {}", account, balance);
    }

    Ok(())
}

如果你想部署你编写的智能合约,你可以这样做(确保你已安装 Solidity 编译器):

solc -o build --bin --abi contracts/*.sol

Solidity 编译器会为 contracts 目录中的智能合约生成二进制文件和 ABI 代码,并输出到名为 build 的目录中。

更多示例请查看 examples 文件夹

Futures 迁移

  • 移除 parking_lot(如果真的需要,替换为异步感知锁)。
  • 考虑移除 Unpin 要求。(#361)
  • WebSockets: TLS 支持 (#360)
  • WebSockets: 重新连接 & Pings
  • 考虑在 ws.rs 传输中使用 tokio 替代 async-std(测试问题)。
  • 恢复 IPC 传输

通用

  • 更灵活的 API(接受 Into<X>
  • 合约调用(ABI 编码;debris/ethabi
  • 批量请求

传输

  • HTTP 传输
  • IPC 传输
  • WebSockets 传输

类型

  • U256,H256,Address(H160) 类型
  • 索引类型(数字,编码为十六进制)
  • 交易类型(来自 Parity 的 Transaction
  • 交易收据类型(来自 Parity 的 TransactionReceipt
  • 区块类型(来自 Parity 的 RichBlock
  • 工作类型(来自 Parity 的 Work
  • 同步类型(来自 Parity 的 SyncStats

APIs

  • Eth: eth_*
  • Eth 过滤器: eth_*
  • Eth pubsub: eth_*
  • net_*
  • web3_*
  • personal_*
  • traces_*

Parity 特定 APIs

  • Parity 只读: parity_*

  • Parity 账户: parity_*(部分实现)

  • Parity 设置: parity_*

  • signer_*

  • 自定义 APIs(可扩展)

let web3 = Web3::new(transport);
web3.api::<CustomNamespace>().custom_method().wait().unwrap()

Windows 安装

目前,Windows 不支持 IPC,而该库默认启用 IPC。 要编译,你需要禁用 IPC 功能:

web3 = { version = "_", default-features = false, features = ["http"] }

避免 OpenSSL 依赖

在 Linux 上,native-tls 使用 OpenSSL 实现。要避免 HTTPS 或 WSS 的这种依赖,请使用相应的功能。

web3 = { version = "_", default-features = false, features = ["http-rustls-tls", "ws-rustls-tokio"] }

注意:要完全复制默认功能,还需添加 signingipc-tokio 功能

Cargo 功能

该库支持以下功能:

  • http - 启用 HTTP 传输(需要 tokio 运行时,因为使用了 hyper)。
  • http-tls - 通过 reqwest/default-tls 为 HTTP 传输启用 TLS 支持(包含 http;默认)。
  • http-native-tls - 通过 reqwest/native-tls 为 HTTP 传输启用 TLS 支持(包含 http)。
  • http-rustls-tls - 通过 reqwest/rustls-tls 为 HTTP 传输启用 TLS 支持(包含 http)。
  • ws-tokio - 使用 tokio 运行时启用 WS 传输。
  • ws-tls-tokio - 为 WS 传输启用 TLS 支持(包含 ws-tokio;默认)。
  • ws-rustls-tokio - 为 WS 传输启用 rustls TLS 支持(包含 ws-tokio)。
  • ws-async-std - 使用 async-std 运行时启用 WS 传输。
  • ws-tls-async-std - 为 WS 传输启用 TLS 支持(包含 ws-async-std)。
  • ipc-tokio - 使用 tokio 运行时启用 IPC 传输(默认)。
  • signing - 启用账户命名空间和本地签名支持(默认)。
  • eip-1193 - 启用 EIP-1193 支持。
  • wasm - 编译为 WASM(确保禁用默认功能)。
  • arbitrary_precision - 在 serde_json 中启用 arbitrary_precision
  • allow-missing-fields - 某些响应字段在以太坊中是必需的,但在兼容 EVM 的链(如 Celo 和 Fantom)中不存在。此功能通过为这些字段设置默认值来实现兼容性。
项目侧边栏1项目侧边栏2
推荐项目
Project Cover

豆包MarsCode

豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。

Project Cover

AI写歌

Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。

Project Cover

有言AI

有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。

Project Cover

Kimi

Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。

Project Cover

阿里绘蛙

绘蛙是阿里巴巴集团推出的革命性AI电商营销平台。利用尖端人工智能技术,为商家提供一键生成商品图和营销文案的服务,显著提升内容创作效率和营销效果。适用于淘宝、天猫等电商平台,让商品第一时间被种草。

Project Cover

吐司

探索Tensor.Art平台的独特AI模型,免费访问各种图像生成与AI训练工具,从Stable Diffusion等基础模型开始,轻松实现创新图像生成。体验前沿的AI技术,推动个人和企业的创新发展。

Project Cover

SubCat字幕猫

SubCat字幕猫APP是一款创新的视频播放器,它将改变您观看视频的方式!SubCat结合了先进的人工智能技术,为您提供即时视频字幕翻译,无论是本地视频还是网络流媒体,让您轻松享受各种语言的内容。

Project Cover

美间AI

美间AI创意设计平台,利用前沿AI技术,为设计师和营销人员提供一站式设计解决方案。从智能海报到3D效果图,再到文案生成,美间让创意设计更简单、更高效。

Project Cover

AIWritePaper论文写作

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号