我需要将使用RsaPrivateKey::new()生成的私钥转换为pem,但无法通过文档了解如何做到这一点。
use rsa::{PublicKey, RsaPrivateKey, RsaPublicKey, PaddingScheme, pkcs8::EncodePrivateKey};
// create a private key
let mut rng = rand::thread_rng();
let bits = 2048;
let private_key = RsaPrivateKey::new(&mut rng, bits).expect("Failed to generate key");
// create a public key / address
let public_key = RsaPublicKey::from(&private_key);创建pem会返回一个错误,说明LineEnding是未声明的,但在文档中是这样做的:
let priv_pem = RsaPrivateKey::to_pkcs8_pem(&private_key, line_ending: LineEnding::default);发布于 2022-06-02 00:13:38
您需要从LineEnding中导入pkcs8,或者将其限定为从该机箱中导入:
use rsa::pkcs8::{LineEnding, EncodePrivateKey};
let priv_pem = RsaPrivateKey::to_pkcs8_pem(&private_key, LineEnding::default);或
use rsa::pkcs8::{self, EncodePrivateKey};
let priv_pem = RsaPrivateKey::to_pkcs8_pem(&private_key, pkcs8::LineEnding::default);https://stackoverflow.com/questions/72469194
复制相似问题