Maison >développement back-end >C++ >Comment lire et utiliser une clé privée PEM RSA pour le décryptage dans .NET ?

Comment lire et utiliser une clé privée PEM RSA pour le décryptage dans .NET ?

Linda Hamilton
Linda Hamiltonoriginal
2025-01-06 11:39:41146parcourir

How to Read and Use a PEM RSA Private Key for Decryption in .NET?

Lecture d'une clé privée PEM RSA dans .NET

Dans .NET, vous pouvez facilement lire une clé privée PEM RSA et instancier un RSACryptoServiceProvider pour décrypter les données chiffrées avec la clé publique correspondante.

.NET 5 Support

.NET 5 offre désormais une prise en charge intégrée pour cette tâche. Pour l'utiliser, procédez comme suit :

  1. Générez une paire de clés et cryptez du texte à l'aide d'un outil en ligne comme http://travistidwell.com/jsencrypt/demo/.
  2. Utilisez l'extrait de code suivant pour importer la clé privée PEM et déchiffrer le texte chiffré :
var privateKey = @"-----BEGIN RSA PRIVATE KEY-----
{ the full PEM private key } 
-----END RSA PRIVATE KEY-----";

var rsa = RSA.Create();
rsa.ImportFromPem(privateKey.ToCharArray());

var decryptedBytes = rsa.Decrypt(
    Convert.FromBase64String("{ base64-encoded encrypted string }"), 
    RSAEncryptionPadding.Pkcs1
);

// this will print the original unencrypted string
Console.WriteLine(Encoding.UTF8.GetString(decryptedBytes));

Solution BouncyCastle originale

Avant .NET 5, la bibliothèque BouncyCastle fournissait une solution :

var bytesToDecrypt = Convert.FromBase64String("la0Cz.....D43g=="); // string to decrypt, base64 encoded

AsymmetricCipherKeyPair keyPair; 

using (var reader = File.OpenText(@"c:\myprivatekey.pem")) // file containing RSA PKCS1 private key
    keyPair = (AsymmetricCipherKeyPair) new PemReader(reader).ReadObject(); 

var decryptEngine = new Pkcs1Encoding(new RsaEngine());
decryptEngine.Init(false, keyPair.Private); 

var decrypted = Encoding.UTF8.GetString(decryptEngine.ProcessBlock(bytesToDecrypt, 0, bytesToDecrypt.Length)); 

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