mirror of
https://github.com/lifegpc/pixiv_downloader.git
synced 2026-06-24 04:37:08 +08:00
Update
This commit is contained in:
@@ -22,22 +22,23 @@ impl RSAKey {
|
||||
}
|
||||
|
||||
pub fn decrypt(&self, data: &[u8]) -> Result<BytesMut, openssl::error::ErrorStack> {
|
||||
let tosize = data.len();
|
||||
let tosize = self.key.size() as usize;
|
||||
let mut buf = BytesMut::with_capacity(tosize);
|
||||
buf.resize(tosize, 0);
|
||||
let mut i = 0;
|
||||
let mut real = 0;
|
||||
while i < tosize {
|
||||
let i2 = i + self.key.size() as usize;
|
||||
real += self
|
||||
.key
|
||||
.private_decrypt(&data[i..i2], &mut buf[i..i2], Padding::PKCS1)?;
|
||||
i = i2;
|
||||
}
|
||||
let real = self.key.private_decrypt(&data, &mut buf, Padding::PKCS1)?;
|
||||
buf.truncate(real);
|
||||
Ok(buf)
|
||||
}
|
||||
|
||||
#[cfg(test)]
|
||||
pub fn encrypt(&self, data: &[u8]) -> Result<BytesMut, openssl::error::ErrorStack> {
|
||||
let tosize = self.key.size() as usize;
|
||||
let mut buf = BytesMut::with_capacity(tosize);
|
||||
buf.resize(tosize, 0);
|
||||
self.key.public_encrypt(&data, &mut buf, Padding::PKCS1)?;
|
||||
Ok(buf)
|
||||
}
|
||||
|
||||
pub fn is_too_old(&self) -> bool {
|
||||
self.generated_time < Utc::now() - chrono::Duration::hours(1)
|
||||
}
|
||||
@@ -120,3 +121,18 @@ impl MatchRoute<Body, Body> for AuthPubkeyRoute {
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn test_rsa_decrypt() {
|
||||
let key = RSAKey::new().unwrap();
|
||||
let data = b"Hello, world!";
|
||||
let enc = key.encrypt(data).unwrap();
|
||||
let dec = key.decrypt(&enc).unwrap();
|
||||
assert_eq!(data, &dec[..]);
|
||||
let mut data = BytesMut::with_capacity(256);
|
||||
data.resize(256, 0);
|
||||
openssl::rand::rand_bytes(&mut data).unwrap();
|
||||
let enc = key.encrypt(&data).unwrap();
|
||||
let dec = key.decrypt(&enc).unwrap();
|
||||
assert_eq!(data, dec);
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user