以太坊JSON-RPC多传输客户端。 Web3.js库的Rust实现。
文档: 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 文件夹。
Unpin
要求。(#361)ws.rs
传输中使用 tokio
替代 async-std
(测试问题)。Into<X>
)debris/ethabi
)U256,H256,Address(H160)
类型Transaction
)TransactionReceipt
)RichBlock
)Work
)SyncStats
)eth_*
eth_*
eth_*
net_*
web3_*
personal_*
traces_*
Parity 只读: parity_*
Parity 账户: parity_*
(部分实现)
Parity 设置: parity_*
signer_*
自定义 APIs(可扩展)
let web3 = Web3::new(transport); web3.api::<CustomNamespace>().custom_method().wait().unwrap()
目前,Windows 不支持 IPC,而该库默认启用 IPC。 要编译,你需要禁用 IPC 功能:
web3 = { version = "_", default-features = false, features = ["http"] }
在 Linux 上,native-tls
使用 OpenSSL 实现。要避免 HTTPS 或 WSS 的这种依赖,请使用相应的功能。
web3 = { version = "_", default-features = false, features = ["http-rustls-tls", "ws-rustls-tokio"] }
注意:要完全复制默认功能,还需添加 signing
和 ipc-tokio
功能。
该库支持以下功能:
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)中不存在。此功能通过为这些字段设置默认值来实现兼容性。字节跳动发布的AI编程神器IDE
Trae是一种自适应的集成开发环境(IDE),通过自动化和多元协作改变开发流程。利用Trae,团队能够更快速、精确地编写和部署代码,从而提高编程效率和项目交付速度。Trae具备上下文感知和代码自动完成功能,是提升开发效率的理想工具。
帮助AI理解电脑屏幕 纯视觉GUI元素的自动化解析方案
开源工具通过计算机视觉技术实现图形界面元素的智能识别与结构化处理,支持自动化测试脚本生成和辅助功能开发。项目采用模块化设计,提供API接口与多种输出格式,适用于跨平台应用场景。核心算法优化了元素定位精度,在动态界面和复杂布局场景下保持稳定解析能力。
埃隆·马斯克旗下的人工智能公司 xAI 推出的第三代大规模语言模型
Grok3 是由埃隆·马斯克旗下的人工智能公司 xAI 推出的第三代大规模语言模型,常被马斯克称为“地球上最聪明的 AI”。它不仅是在前代产品 Grok 1 和 Grok 2 基础上的一次飞跃,还在多个关键技术上实现了创新突破。
腾讯自研的混元大模型AI助手
腾讯元宝是腾讯基于自研的混元大模型推出的一款多功能AI应用,旨在通过人工智能技术提升用户在写作、绘画、翻译、编程、搜索、阅读总结等多个领域的工作与生活效率。
Windsurf Editor推出第三次重大更新Wave 3
新增模型上下文协议支持与智能编辑功能。本次更新包含五项核心改进:支持接入MCP协议扩展工具生态,Tab键智能跳转提升编码效率,Turbo模式实现自动化终端操作,图片拖拽功能优化多模态交互,以及面向付费用户的个性化图标定制。系统同步集成DeepSeek、Gemini等新模型,并通过信用点数机制实现差异化的资源调配。
增强编程效率的AI代码编辑器
Cursor作为AI驱动的代码编辑工具,助力开发者效率大幅度提升。该工具简化了扩展、主题和键位配置的导入,可靠的隐私保护措施保证代码安全,深受全球开发者信赖。此外,Cursor持续推出更新,不断优化功能和用户体验。
全面超越基准的 AI Agent助手
Manus 是一款通用人工智能代理平台,能够将您的创意和想法迅速转化为实际成果。无论是定制旅行规划、深入的数据分析,还是教育支持与商业决策,Manus 都能高效整合信息,提供精准解决方案。它以直观的交互体验和领先的技术,为用户开启了一个智慧驱动、轻松高效的新时代,让每个灵感都能得到完美落地。
飞书官方推出的AI知识库 上传word pdf即可部署AI私有知识库
基于DeepSeek R1大模型构建的知识管理系统,支持PDF、Word、PPT等常见文档格式解析,实现云端与本地数据的双向同步。系统具备实时网络检索能力,可自 动关联外部信息源,通过语义理解技术处理结构化与非结构化数据。免费版本提供基础知识库搭建功能,适用于企业文档管理和个人学习资料整理场景。
大模型驱动的Excel数据处理工具
基于大模型交互的表格处理系统,允许用户通过对话方式完成数据整理和可视化分析。系统采用机器学习算法解析用户指令,自动执行排序、公式计算和数据透视等操作,支持多种文件格式导入导出。数据处理响应速度保持在0.8秒以内,支持超过100万行数据的即时分析。
DeepSeek开源的专家并行通信优化框架
DeepEP是一个专为大规模分布式计算设计的通信库,重点解决专家并行模式中的通信瓶颈问题。其核心架构采用分层拓扑感知技术,能够自动识别节点间物理连接关系,优化数据传输路径。通过实现动态路由选择与负载均衡机制,系统在千卡级计算集群中维持稳定的低延迟特性,同时兼容主流深度学习框架的通信接口。
最新AI工具、AI资讯
独家AI资源、AI项目落地
微信扫一扫关注公众号