区块链开发必备的9个Rust包

简介: Rust是新一代的潜力巨大的开发语言。本文编辑整理了9个主流的用于以太坊、比特币、tendermint、eosio、polkadot等区块链开发的Rust包,可用于区块链应用的快速开发。

Rust是新一代的潜力巨大的开发语言。本文编辑整理了9个主流的用于以太坊、比特币、tendermint、eosio、polkadot等区块链开发的Rust包,可用于区块链应用的快速开发。

区块链开发教程链接: 以太坊 | 比特币 | EOS | Tendermint | Hyperledger Fabric | Omni/USDT | Ripple

1、rust-bitcoin:比特币区块链rust开发包

rust-bitcoin用于开发比特币区块链相关应用,支持序列化/反序列化、解析并执行比特币相关数据结构及网络消息等功能,具体支持的特性包括:

  • 比特币协议消息的序列化/反序列化
  • 比特币区块和交易的序列化/反序列化
  • 比特币脚本的序列化/反序列化
  • 私钥和地址的创建、序列化/反序列化和验证,内置BIP32的完整支持
  • PSBT的创建、操作、合并与最终化
  • 支持Blockstream侧链的Pay-to-contract交易

项目地址:https://github.com/rust-bitcoin/rust-bitcoin

2、rust-bitcoincore-rpc:比特币节点JSON-RPC API客户端开发包

rust-bitcoin不包含比特币节点的JSON RPC API封装,rust-bitcoincore-rpc填补了这个空白。例如:

let rpc = Client::new(url, Auth::UserPass(user, pass)).unwrap();

let _blockchain_info = rpc.get_blockchain_info()?;

let best_block_hash = rpc.get_best_block_hash()?;
println!("best block hash: {}", best_block_hash);
let bestblockcount = rpc.get_block_count()?;
println!("best block height: {}", bestblockcount);
let best_block_hash_by_height = rpc.get_block_hash(bestblockcount)?;
println!("best block hash by height: {}", best_block_hash_by_height);
assert_eq!(best_block_hash_by_height, best_block_hash);

let bitcoin_block: bitcoin::Block = rpc.get_by_id(&best_block_hash)?;
println!("best block hash by `get`: {}", bitcoin_block.header.prev_blockhash);
let bitcoin_tx: bitcoin::Transaction = rpc.get_by_id(&bitcoin_block.txdata[0].txid())?;
println!("tx by `get`: {}", bitcoin_tx.txid());

项目地址:https://github.com/rust-bitcoin/rust-bitcoincore-rpc/tree/master/client

3、rust-web3:以太坊区块链rust开发包

rust-web3是以太坊web3.js开发包的rust版本的实现,具体特性包括:

  • 支持合约调用、ABI编码
  • 支持批量请求
  • 支持HTTP/IPC/WebSocket传输
  • 支持众多标准或非标数据类型,例如:

    • U256,H256,Address(H160)
    • Parity的Transaction、TransactionReceipt 、RichBlock、Work、SyncStats
  • 支持大部分标准以太坊RPC API

    • Eth:eth_*:支持
    • Eth Filters:eth_*:支持
    • Eth Pubsub:eth_*:支持
    • net_*:支持
    • web3_*:支持
    • personal_*:支持
    • traces_*:暂不支持
  • 支持Parity扩展RPC API:

    • 只读api:parity_*:支持
    • 账户api:parity_*:部分支持
    • 集合api:parity_*:支持
    • signer_*:支持
    • 自定义API:支持

项目地址:https://github.com/tomusdrw/rust-web3/

4、ethereum-tx-sign:以太坊离线签名rust开发包

ethereum-tx-sign支持你在Rust代码中脱机签名以太坊交易。例如:

// 1 mainnet, 3 ropsten
const ETH_CHAIN_ID: u32 = 3;

let tx = ethereum_tx_sign::RawTransaction {
    nonce: web3::types::U256::from(0),
    to: Some(web3::types::H160::zero()),
    value: web3::types::U256::zero(),
    gas_price: web3::types::U256::from(10000),
    gas: web3::types::U256::from(21240),
    data: hex::decode(
        "7f7465737432000000000000000000000000000000000000000000000000000000600057"
    ).unwrap(),
};

let mut data: [u8; 32] = Default::default();
data.copy_from_slice(&hex::decode(
    "2a3526dd05ad2ebba87673f711ef8c336115254ef8fcd38c4d8166db9a8120e4"
).unwrap());
let private_key = web3::types::H256(data);
let raw_rlp_bytes = tx.sign(&private_key, &ETH_CHAIN_ID);

let result = "f885808227108252f894000000000000000000000000000000000000000080a\
    47f746573743200000000000000000000000000000000000000000000000000\
    00006000572aa0b4e0309bc4953b1ca0c7eb7c0d15cc812eb4417cbd759aa09\
    3d38cb72851a14ca036e4ee3f3dbb25d6f7b8bd4dac0b4b5c717708d20ae6ff\
    08b6f71cbf0b9ad2f4";
assert_eq!(result, hex::encode(raw_rlp_bytes));

项目地址:https://github.com/synlestidae/ethereum-tx-sign

5、SputnikVM:纯rust实现的以太坊虚拟机

SputnikVM是完全采用rust实现的以太坊虚拟机,主要特性包括:

  • 独立:可以作为单独进程载入或集成进现有APP
  • 通用:支持不同的以太坊区块链,例如ETC、ETH或私有链
  • 无状态:只包含一个连接到独立的状态存储的执行环境
  • 快速:实现的关注重点就是性能

SputnikVM要求 rustc 1.33.0 (2aa4c46cf 2019-02-28),不支持 Rust 1.32.0以及更早版本。

项目地址:https://github.com/rust-blockchain/evm

6、tendermint-rs:tendermint区块链rust开发包

Tendermint是一个高性能的支持拜占庭容错的区块链共识引擎,tendermint-rs用于访问Tendermint区块链,要求Rust 1.39+。

项目地址:https://github.com/informalsystems/tendermint-rs/tree/master/tendermint

7、monero-rs:Monero区块链rust开发包

monero-rs用于访问Monero区块链,支持门罗币相关的序列化/反序列化以及数据结构或网络消息的解析。具体特性包括:

  • 支持Monero区块及交易的序列化/反序列化
  • 支持地址和子地址的创建、序列化/反序列化和验证
  • 支持私钥和一次性密钥的创建、序列化/反序列化和验证
  • 大部分结构都支持Serde

项目地址:https://github.com/monero-rs/monero-rs

8、eosio-rust:EOSIO区块链rust开发包

eosio-rust是Rust版本的EOSIO SDK,它提供一组API用于采用Rust开发EOSIO区块链上的智能合约与全栈应用。

项目地址:https://github.com/sagan-software/eosio-rust

9、substrate:大杀器

Parity出品,支持区块链创新的下一代开发框架,已经用于Polkadot的开发,是中小企业开发自主知识产权的的区块链平台的一大利器。

项目地址:https://github.com/paritytech/substrate


原文链接:9个主流的Rust区块链开发包 — 汇智网

目录
相关文章
|
2月前
|
存储 开发框架 API
Codefi基于区块链的开发框架
Codefi基于区块链的开发框架
71 0
|
2月前
|
供应链 安全 物联网
【专栏】区块链和智能合约的未来发展潜力巨大,期待更多创新应用
【4月更文挑战第27天】本文探讨了区块链技术与智能合约的边界及挑战。区块链,以其不可篡改和安全特性,广泛应用于金融、供应链和物联网等领域。智能合约作为区块链上的自动执行代码,实现无需第三方的可信交易。然而,技术上面临扩展性、性能和安全问题,法律与监管层面也需适应智能合约的自动执行特性及跨境法律协调。尽管挑战重重,区块链和智能合约的未来发展潜力巨大,期待更多创新应用。
|
9天前
|
Rust 程序员 开发者
使用 Rust 开发一款类似于 GitBook 的程序
**Rust新手开发者分享开源项目 Typikon**:模仿MDBook,致力于简单Markdown到在线书的渲染。[GitHub](https://github.com/auula/typikon)上可找到源码,欢迎初学者一同学习与贡献。体验轻松构建静态网站,探索Rust之旅。🌟 加入讨论,共建更易用的GitBook替代品。在线文档见[https://typikonbook.github.io](https://typikonbook.github.io)。
13 1
|
1月前
|
供应链 物联网 分布式数据库
区块链技术与智能合约开发的边界究竟在哪里?
【6月更文挑战第10天】本文探讨了区块链技术与智能合约的界限和挑战。区块链,本质是分布式数据库,以其不可篡改性和安全性在金融、供应链和物联网等领域广泛应用。智能合约,作为区块链上的自动执行代码,无需第三方介入,确保了执行的自动性和安全性。然而,技术上面临扩展性、性能和安全问题,法律与监管层则需解决合规监管和跨国法律协调的难题。尽管如此,随着技术进步和应用场景拓展,区块链与智能合约的潜力和未来前景依然广阔。
42 2
|
1月前
|
数据可视化 安全 区块链
区块链钱包浏览器开发功能,价格和时间周期
开发区块链钱包浏览器涉及账户管理、交易查询、区块浏览、智能合约查询及数据可视化等功能。价格因开发难度、需求、团队专业度及第三方服务费用而异,通常在数万至数百万元。开发周期约数月到半年,包括需求分析、设计、开发、测试和上线等阶段。
区块链钱包浏览器开发功能,价格和时间周期
|
1月前
|
敏捷开发 安全 测试技术
区块链开发团队DappNetWork
区块链开发团队由跨学科专家组成,包括区块链专家、智能合约开发者、系统架构师和测试工程师。团队负责战略规划、技术开发、系统测试和运维优化,需要深入理解区块链技术、安全性和敏捷开发。通过敏捷管理和自动化工具,团队实现高效协作,为金融、供应链等领域提供安全可靠的区块链应用解决方案。如需开发加V:DappNetWork
|
17天前
|
Rust Unix Windows
使用Cargo国内镜像提升Rust开发效率
使用Cargo国内镜像提升Rust开发效率
17 0
|
2月前
|
测试技术 区块链
swap开发/区块链跨链技术系统开发规则
跨链技术通过验证源链状态和中继交易至目标链实现交互,关键组件是跨链桥,用于通证在不同链间的转移。桥通过智能合约锁定/销毁源链通证并在目标链解锁/铸造。简单的跨链桥仅适用于通证传输,而可编程通证桥支持更复杂交互,如交易中的交换、借贷等。任意数据消息传递协议则提供更通用功能,能构建跨链DApp,如跨链DEX、NFT和游戏。
|
2月前
|
Rust 安全 程序员
拜登:“一切非 Rust 项目均为非法”,开发界要大变天?
白宫国家网络总监办公室(ONCD,以下简称网总办)在本周一发布的报告中说道:“程序员编写代码并非没有后果,他们的⼯作⽅式于国家利益而言至关重要。”
65 1
|
2月前
|
自然语言处理 安全 AndFix
区块链商城系统开发步骤指南/详细需求/源码功能/多语言/海外版
When developing a blockchain mall system, the following steps and requirements are usually required: