首页 >后端开发 >C++ >如何从 .NET 中的 PEM 文件检索 RSA 私钥?

如何从 .NET 中的 PEM 文件检索 RSA 私钥?

DDD
DDD原创
2025-01-06 11:34:41271浏览

How to Retrieve an RSA Private Key from a PEM File in .NET?

.NET 中从 PEM 格式检索 RSA 私钥

在 .NET 中,读取 PEM 格式的 RSA 私钥并初始化 RSACryptoServiceProvider解密使用相应公钥加密的数据的实例需要特定步骤。本文概述了完成此任务的两种方法。

.NET 5 及更高版本

从 .NET 5 开始,可以使用内置功能来读取 PEM 私有键:

var privateKey = @"-----BEGIN RSA PRIVATE KEY-----
{ the full PEM private key } 
-----END RSA PRIVATE KEY-----";

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

预安装库

对于早期版本的.NET 或如果内置功能不合适,BouncyCastle 等外部库提供了解决方案:

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));

以上是如何从 .NET 中的 PEM 文件检索 RSA 私钥?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn