Module openssl::rsa [−][src]
Rivest–Shamir–Adleman cryptosystem
RSA is one of the earliest asymmetric public key encryption schemes. Like many other cryptosystems, RSA relies on the presumed difficulty of a hard mathematical problem, namely factorization of the product of two large prime numbers. At the moment there does exist an algorithm that can factor such large numbers in reasonable time. RSA is used in a wide variety of applications including digital signatures and key exchanges such as establishing a TLS/SSL connection.
The RSA acronym is derived from the first letters of the surnames of the algorithm's founding trio.
Example
Generate a 2048-bit RSA key pair and use the public key to encrypt some data.
extern crate openssl; use openssl::rsa::{Rsa, Padding}; fn main() { let rsa = Rsa::generate(2048).unwrap(); let data: Vec<u8> = String::from("foobar").into_bytes(); let mut encrypted_data: Vec<u8> = vec![0; 512]; let padding = Padding::PKCS1; let _ = rsa.public_encrypt(&data, encrypted_data.as_mut_slice(), padding).unwrap(); }
Structs
Padding |
Type of encryption padding to use. |
Rsa |
An RSA key. |
RsaPrivateKeyBuilder | |
RsaRef |
Reference to |