Maison >développement back-end >Golang >Comment stocker en toute sécurité les clés privées ECDSA dans Go ?

Comment stocker en toute sécurité les clés privées ECDSA dans Go ?

Barbara Streisand
Barbara Streisandoriginal
2024-11-11 05:08:02941parcourir

How do you securely store ECDSA private keys in Go?

Stockage des clés privées ECDSA dans Go : un guide complet

Lorsque vous travaillez avec ECDSA (algorithme de signature numérique à courbe elliptique) dans Go, cela devient nécessaire pour stocker la clé privée en toute sécurité. La méthode ecdsa.GenerateKey fournit un moyen de créer une paire de clés privée/publique, mais laisse le stockage de la clé privée au développeur. Ce guide approfondira l'approche recommandée pour stocker les clés privées ECDSA dans Go.

Marshaling personnalisé vs. Encodage standard

La question se pose de savoir s'il faut implémenter manuellement le marshaling de clé ou utiliser une méthode de codage standard. L'approche recommandée consiste à exploiter les bibliothèques Go standard pour le stockage des clés. Cela garantit l'interopérabilité avec d'autres applications et est conforme aux meilleures pratiques de l'industrie.

Encodage PEM : une option polyvalente

L'encodage PEM (Privacy-Enhanced Mail) est une méthode largement adoptée. norme pour le stockage des clés. Il intègre plusieurs étapes :

  1. Algorithme cryptographique : L'algorithme ECDSA est utilisé pour la génération de clés.
  2. Encodage X.509 :Le la clé privée est codée au format X.509, couramment utilisé pour certificats.
  3. Format PEM :Le résultat est enveloppé dans des blocs PEM pour faciliter la manipulation.

Clés d'encodage et de décodage

L'exemple de code suivant montre comment encoder et décoder les clés ECDSA à l'aide de PEM encodage :

import (
    "crypto/ecdsa"
    "crypto/elliptic"
    "crypto/pem"
    "crypto/rand"
    "fmt"
    "reflect"
)

func encode(privateKey *ecdsa.PrivateKey, publicKey *ecdsa.PublicKey) (string, string) {
    // Marshal the private key to X.509 format
    x509Encoded, _ := x509.MarshalECPrivateKey(privateKey)

    // Encode the X.509-formatted key into PEM format
    pemEncoded := pem.EncodeToMemory(&pem.Block{Type: "PRIVATE KEY", Bytes: x509Encoded})

    // Marshal the public key to X.509 format
    x509EncodedPub, _ := x509.MarshalPKIXPublicKey(publicKey)

    // Encode the X.509-formatted public key into PEM format
    pemEncodedPub := pem.EncodeToMemory(&pem.Block{Type: "PUBLIC KEY", Bytes: x509EncodedPub})

    return string(pemEncoded), string(pemEncodedPub)
}

func decode(pemEncoded string, pemEncodedPub string) (*ecdsa.PrivateKey, *ecdsa.PublicKey) {
    // Decode the PEM-encoded private key from a string
    block, _ := pem.Decode([]byte(pemEncoded))

    // Extract the X.509-formatted private key from the PEM block
    x509Encoded := block.Bytes

    // Parse the X.509-formatted private key
    privateKey, _ := x509.ParseECPrivateKey(x509Encoded)

    // Decode the PEM-encoded public key from a string
    blockPub, _ := pem.Decode([]byte(pemEncodedPub))

    // Extract the X.509-formatted public key from the PEM block
    x509EncodedPub := blockPub.Bytes

    // Parse the X.509-formatted public key
    genericPublicKey, _ := x509.ParsePKIXPublicKey(x509EncodedPub)

    // Convert the generic public key to an ecdsa.PublicKey
    publicKey := genericPublicKey.(*ecdsa.PublicKey)

    return privateKey, publicKey
}

// Test the encoding and decoding functionality
func test() {
    // Generate an ECDSA key pair
    privateKey, _ := ecdsa.GenerateKey(elliptic.P384(), rand.Reader)
    publicKey := &privateKey.PublicKey

    // Encode the key pair into PEM
    encPriv, encPub := encode(privateKey, publicKey)

    // Decode the PEM-encoded key pair
    priv2, pub2 := decode(encPriv, encPub)

    // Compare the original and decoded keys
    if !reflect.DeepEqual(privateKey, priv2) {
        fmt.Println("Private keys do not match.")
    }
    if !reflect.DeepEqual(publicKey, pub2) {
        fmt.Println("Public keys do not match.")
    }
}

En tirant parti de ces techniques, les développeurs peuvent stocker et gérer en toute sécurité les clés privées ECDSA dans Go. Le codage PEM fournit un format robuste et largement accepté pour stocker les clés, permettant l'interopérabilité avec diverses applications et garantissant l'intégrité des données.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn