Enregistrement et chargement des clés privées et publiques pour le cryptage RSA
Lorsque vous travaillez avec le package crypto/rsa dans Go, il devient nécessaire de stocker et récupérez les clés privées et publiques en toute sécurité. Cet article fournit des conseils complets sur la manière de gérer correctement la tâche de conservation de ces clés sur le disque et de les restaurer en cas de besoin.
Enregistrement des clés privées RSA
Pour créer une tranche d'octets représentant un rsa.PrivateKey, utilisez la fonction suivante :
func x509.MarshalPKCS1PrivateKey(key *rsa.PrivateKey) []byte
Cette fonction rassemble la clé privée en une tranche d'octets suivant le Norme PKCS#1.
Enregistrement des clés publiques RSA
Pour rsa.PublicKey, il n'y a pas de fonction intégrée dans la bibliothèque standard Go pour rassembler la clé dans un tranche d'octets. Cependant, il est courant d'encoder la clé privée marshalée dans un fichier PEM à l'aide du code suivant :
pemdata := pem.EncodeToMemory( &pem.Block{ Type: "RSA PRIVATE KEY", Bytes: x509.MarshalPKCS1PrivateKey(key), }, )
Cet extrait de code enveloppe la clé privée marshalée dans un bloc PEM et l'encode dans un fichier au format PEM. tranche d'octets.
Chargement de RSA privé et public Clés
Pour charger une clé privée RSA à partir d'un disque ou d'une mémoire, utilisez la fonction suivante :
func x509.ParsePKCS1PrivateKey(der []byte) (key *rsa.PrivateKey, err error)
Cette fonction analyse une tranche d'octets de clé privée codée en DER et renvoie un Objet rsa.PrivateKey.
Étant donné que les clés publiques n'ont pas leur propre fonction d'analyse, vous devrez extraire la clé publique du privé clé si vous avez les deux chargés. Pour extraire la clé publique d'une clé privée, utilisez le code suivant :
pub := &key.PublicKey
Conclusion
Ce guide complet fournit les informations et fonctions nécessaires pour sauvegarder et chargement des clés privées et publiques RSA dans Go, garantissant une bonne gestion et accessibilité de ces clés pour les opérations cryptographiques.
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!