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 run

Sortie

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