特征“rand_core::CryptoRng”没有为“OsRng”实现

who*_*iac 9 random rust ed25519

我一直在尝试实现以下文档中给出的示例:https ://docs.rs/ed25519-dalek/1.0.1/ed25519_dalek/

我的代码很简单:

extern crate rand;
extern crate ed25519_dalek;


use rand::rngs::OsRng;
use ed25519_dalek::Keypair;


fn main() {
    let mut csprng = OsRng{};
    let keypair: Keypair = Keypair::generate(&mut csprng);
}
Run Code Online (Sandbox Code Playgroud)

但是当我尝试运行时,我收到一条错误消息,指出该CryptoRng特征未在OsRng

11  |     let keypair: Keypair = Keypair::generate(&mut csprng);
    |                                              ^^^^^^^^^^^ the trait `rand_core::CryptoRng` is not implemented for `OsRng`
Run Code Online (Sandbox Code Playgroud)

然而,CryptoRng这只是一个标记特征,我看到它确实有一个空的隐含OsRng......

那么这里可能存在什么问题呢?

Apl*_*123 17

通常,当您收到这些令人困惑的消息时,如果明确满足了“特征绑定未满足”,或者在显然是正确的类型时显示“类型错误”,则应该始终检查包版本。截至目前(ed25519-dalek v1.0.1),它取决于 rand 0.7.0(您也可以在 crates.io 上找到它)。您使用的是较新版本的 rand,具有“较新”版本的特征,并且在您提供 0.8.0 特征时,它正在寻找 0.7.0 特征。

解决方案?将 rand 降级到 0.7.0 或使用依赖项重命名来拥有 2 个版本的 rand,并为 ec25519-dalek 使用旧版本。