Exemple Rust : Générer une paire de clés publique/privée avec sodiumoxide et sauvegarder dans un fichier
Ce simple programme Rust montre comment générer une paire de clés publique/privée à l’aide de la crate sodiumoxide et sauvegarder les clés dans des fichiers au format base64.
src/main.rs
use sodiumoxide::crypto::sign;
use std::fs::File;
use std::io::Write;
use std::path::Path;
use base64::{Engine as _, engine::general_purpose};
fn main() -> Result<(), Box<dyn std::error::Error>> {
// Initialiser sodiumoxide
sodiumoxide::init().expect("Échec de l'initialisation de sodiumoxide");
// Générer une nouvelle paire de clés
let (public_key, secret_key) = sign::gen_keypair();
// Convertir les clés en base64
let public_key_b64 = general_purpose::STANDARD.encode(public_key.as_ref());
let secret_key_b64 = general_purpose::STANDARD.encode(secret_key.as_ref());
// Définir les chemins des fichiers
let public_key_path = Path::new("public_key.b64");
let secret_key_path = Path::new("secret_key.b64");
// Sauvegarder la clé publique dans un fichier
let mut public_key_file = File::create(public_key_path)?;
public_key_file.write_all(public_key_b64.as_bytes())?;
// Sauvegarder la clé secrète dans un fichier
let mut secret_key_file = File::create(secret_key_path)?;
secret_key_file.write_all(secret_key_b64.as_bytes())?;
println!("Paire de clés générée et sauvegardée avec succès !");
println!("Clé publique sauvegardée dans : {:?}", public_key_path);
println!("Clé secrète sauvegardée dans : {:?}", secret_key_path);
Ok(())
}Cargo.toml
[package]
name = "MakeKeyPair"
version = "0.1.0"
edition = "2021"
[dependencies]
sodiumoxide = "0.2"
base64 = "0.21"Comment exécuter
run.sh
cargo runSortie
output.txt
Clé publique sauvegardée dans : "public_key.b64"
Clé secrète sauvegardée dans : "secret_key.b64"Check out similar posts by category:
Cryptography, Rust
If this post helped you, please consider buying me a coffee or donating via PayPal to support research & publishing of new posts on TechOverflow