4 个版本 (2 个破坏性更新)
0.3.0 | 2023年5月31日 |
---|---|
0.2.1 | 2019年10月15日 |
0.2.0 | 2019年9月28日 |
0.1.0 | 2019年3月28日 |
#13 in #drop-in
每月153次 下载
用于 ethsign
9KB
148 行
ethsign
一个用于读取JSON密钥文件并签名以太坊内容的库。
用法
use ethsign::{Protected, KeyFile};
fn main() {
let file = std::fs::File::open("./res/wallet.json").unwrap();
let key: KeyFile = serde_json::from_reader(file).unwrap();
let password: Protected = "".into();
let secret = key.to_secret_key(&password).unwrap();
let message = [1_u8; 32];
// Sign the message
let signature = secret.sign(&message).unwrap();
println!("{:?}", signature);
// Recover the signer
let public = signature.recover(&message).unwrap();
println!("{:?}", public);
// Verify the signature
let res = public.verify(&signature, &message).unwrap();
println!("{}", if res { "signature correct" } else { "invalid signature" });
}
一个更高级的库 ethkey
便于管理密钥文件,并公开 ethsign
[dependencies]
ethkey = "0.3"
use ethkey::prelude::*;
fn main() {
let key = EthAccount::load_or_generate("/tmp/path/to/keystore", "passwd")
.expect("should load or generate new eth key");
println!("{:?}", key.address());
let message = [7_u8; 32];
// sign the message
let signature = key.sign(&message).unwrap();
// verify the signature
let result = key.verify(&signature, &message).unwrap();
println!("{}", if result {"verification ok"} else {"wrong signature"});
}
lib.rs
:
纯Rust实现的 parity-crypto 库的替代品。
依赖关系
~2.5MB
~46K SLoC