rust的openssl中有支持RSA加解密的库。参考地址如下:
里面也有简单的示例代码:
use openssl::rsa::{Rsa, Padding};
let rsa = Rsa::generate(2048).unwrap();
let data = b"foobar";
let mut buf = vec![0; rsa.size() as usize];
let encrypted_len = rsa.public_encrypt(data, &mut buf, Padding::PKCS1).unwrap();
上述代码使用公钥加密数据。参考类似的代码,我们需要写一个加解密文件的操作,
加密代码:
let buff_size = pub_key.size() as usize;
let mut buf = vec![0;buff_size];
let mut start:usize = 0;
//if use Padding::PKCS1 =>encrypt length = key length - 11
//if use Padding::OAEP =>encrypt length = key length - 42
let mut encrypt_len = 0;
if self.m_padding