Files
simple-rust-tests/__crypto/jose-test/src/main.rs
2024-11-13 01:14:34 +08:00

69 lines
2.3 KiB
Rust

mod jose;
use crate::jose::{deserialize_jwe_aes, serialize_jwe_aes_2};
use base64::engine::general_purpose::STANDARD;
use base64::Engine;
use jose_jwk::{Jwk, Key, Rsa};
use rand::random;
use rand::rngs::ThreadRng;
use rsa::traits::{PrivateKeyParts, PublicKeyParts};
use rsa::Pkcs1v15Encrypt;
fn main() {
let key: [u8; 32] = random();
let payload = b"hello world";
let e = serialize_jwe_aes_2(payload, key).unwrap();
println!("{}", e);
let (d, h) = deserialize_jwe_aes(&e, &key).unwrap();
println!("{:?}", d);
println!("{:?}", h);
let rsa_key = jose::generate_rsa_key_2(2048).unwrap();
let rsa_public_key = rsa_key.as_ref();
let public_rsa: Rsa = rsa_public_key.into();
// let rsa: Rsa = rsa_key.into();
// println!("{:?}", public_rsa);
// println!("{:?}", rsa);
let jwk = Jwk {
key: Key::Rsa(public_rsa),
prm: Default::default(),
};
println!("{}", serde_json::to_string(&jwk).unwrap());
// let rsa_key_2: RsaPrivateKey = rsa.try_into().unwrap();
// println!("{:?}", rsa_key_2);
main2();
}
fn main2() {
let rsa_jwk = r##"{
"kty":"RSA",
"e":"AQAB",
"n":"5xyyPQx8Z7AjVf8Mg4xTE6yN8efPHc0lCdO056R2lzaEQeFwVCbOxFCnmly2-HtE_F_Wd3-B0nxOmODIyC4T
kLS3hXuflZb-OH73GwYDRmfcvWorACm0hv_a3p8YCuXvZ9aQUPRXwLn1jmAnKJiVRtObZTmmG5TsO-Q-U1DJjKhuP
--4co9T434y3U9xGIBYAudQ8tn4QSuVInrO2svg4gb9PExLDBn_46yEiLn-q0TzvO-s2rZ0iCpfB0Gji3djQiF-op
WUjLeGIMLC-gwAOKB4PjlsJBPlIg3pYpRuUEDERIy7kxZ8PIe4Nrfli_sRwMknm9HgQaigu3euYcjxXG9CALTs_vR
a7lRdpEKQY1ysY_z0bjIk1v-erEyNflQimpDHXGxujVj1EUrYz2diu60acmLSEciThafweAupr_qyKXUutBsc_KPK
33n8KBIPjl8X7bX2z-dXMKXo312vfPb6iO1ZcoFXG2nkFzwvFUKYFHSGjuZTQKgiaVEhlbq7N-80BlynnkHLYGcbn
9MtrT8O2Fci1i2ByxyL6B3vB1D5J1VyZ7IBY5AD1GanK2uFmC9nAoFvjTQJt3k2TI_MiPHgb1fZkHu0r-yrf9W_Hr
PrhBTp5wbepRSC6hs-yTykLJKSE5CD43KbjoW5GCqOkkQMnVjvSY4FpAdTj8Qt7kk"
}"##;
let rsa_jwk = rsa_jwk.replace(" ", "");
let rsa_jwk = rsa_jwk.replace("\r", "");
let rsa_jwk = rsa_jwk.replace("\n", "");
println!("{}", rsa_jwk);
let rsa: Rsa = serde_json::from_str(&rsa_jwk).unwrap();
let rsa_public_key = rsa::RsaPublicKey::try_from(rsa).unwrap();
// println!("{:?}", rsa_public_key);
let mut r = ThreadRng::default();
let enc = rsa_public_key.encrypt(&mut r, Pkcs1v15Encrypt, b"aaaaaaaa").unwrap();
println!("{}", STANDARD.encode(&enc));
}