Maison > Article > développement back-end > Comment convertir les clés OpenSSL RSA pour les utiliser avec .Net ?
Utilisation de la clé OpenSSL RSA avec .Net
OpenSSL propose différents formats de clé, provoquant des problèmes de compatibilité avec différents modules.
Problème : .Net nécessite une clé au format "-----BEGIN PUBLIC KEY-----", plutôt que "-----BEGIN RSA PUBLIC KEY-----" format généré par OpenSSL.
Solution :
Utilisez PEM_write_bio_PUBKEY au lieu de PEM_write_bio_RSAPublicKey pour écrire la clé publique. PEM_write_bio_PUBKEY inclut la structure "SubjectPublicKeyInfo" requise, tandis que PEM_write_bio_RSAPublicKey ne génère que la clé publique.
Conversion des clés au format requis :
Pour convertir une clé OpenSSL RSA en format requis par .Net, vous pouvez utiliser le code suivant :
<code class="cpp">BIO_FILE_ptr pem1(BIO_new_file("rsa-public-1.pem", "w"), ::BIO_free); EVP_KEY_ptr pkey(EVP_PKEY_new(), ::EVP_PKEY_free); rc = RSA_generate_key_ex(rsa.get(), 2048, bn.get(), NULL); ASSERT(rc == 1); rc = EVP_PKEY_set1_RSA(pkey.get(), rsa.get()); ASSERT(rc == 1); rc = PEM_write_bio_PUBKEY(pem1.get(), pkey.get()); ASSERT(rc == 1);</code>
Cela créera un fichier PEM nommé "rsa-public-1.pem" contenant la clé publique au format requis.
Exemple :
Considérons l'exemple suivant, où la variable "publicKey" contient une clé au format non reconnu par .Net :
<code class="cpp">string publicKey = @"-----BEGIN RSA PUBLIC KEY----- ... -----END RSA PUBLIC KEY-----"; CryptoKey key = CryptoKey.FromPublicKey(publicKey, ""); RSA rsa = key.GetRSA();</code>
Remplacement "publicKey" avec la clé générée à l'aide du code fourni résoudra l'exception rencontrée lors de la tentative de création d'un objet CryptoKey.
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!