Rust-Beispiel: Öffentliches/privates Schlüsselpaar mit sodiumoxide generieren und in Datei speichern

Dieses einfache Rust-Programm demonstriert, wie man ein öffentliches/privates Schlüsselpaar mit der sodiumoxide-Crate generiert und die Schlüssel in Base64-Format in Dateien speichert.

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>> {
    // Initialize sodiumoxide
    sodiumoxide::init().expect("Failed to initialize sodiumoxide");

    // Generate a new key pair
    let (public_key, secret_key) = sign::gen_keypair();

    // Convert keys to 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());

    // Define file paths
    let public_key_path = Path::new("public_key.b64");
    let secret_key_path = Path::new("secret_key.b64");

    // Save public key to file
    let mut public_key_file = File::create(public_key_path)?;
    public_key_file.write_all(public_key_b64.as_bytes())?;

    // Save secret key to file
    let mut secret_key_file = File::create(secret_key_path)?;
    secret_key_file.write_all(secret_key_b64.as_bytes())?;

    println!("Key pair generated and saved successfully!");
    println!("Public key saved to: {:?}", public_key_path);
    println!("Secret key saved to: {:?}", secret_key_path);

    Ok(())
}
Cargo.toml
[package]
name = "MakeKeyPair"
version = "0.1.0"
edition = "2021"

[dependencies]
sodiumoxide = "0.2"
base64 = "0.21"

Wie man es ausführt

run.sh
cargo run

Ausgabe

output.txt
Public key saved to: "public_key.b64"
Secret key saved to: "secret_key.b64"

Check out similar posts by category: Cryptography, Rust