如何从PEM文件中读取RSA公钥,并使用它在C#中的BouncyCastle中进行加密?

时间:2019-06-07 08:13:25

标签: c# .net-core cryptography rsa bouncycastle

C#BouncyCastle包含一个名为Org.BouncyCastle.Utilities.IO.Pem.PemReader的类,该类似乎采用PEM格式的RSA公钥文件。我看了以下链接:how can i convert pem public key to rsa public key with bouncycastle in c#?

但是它似乎在PemReader上使用了不存在的称为ReadObject的方法。所以我改写了以下代码。

var pemReader = new PemReader(File.OpenText(@"...rsa public key file path ..."));
var pemObject = pemReader.ReadPemObject();
var rsaPublicKeyBytes = pemObject.Content;

一旦我获得了RSA公共字节,就不确定如何继续进行。我希望能够执行以下操作:

var rsaCipher = new RsaEngine();
var oaepEncoding = new OaepEncoding(rsaCipher, new Sha256Digest());
var publicKey = new RsaKeyParameters(...);
oaepEncoding.Init(true, publicKey);
var actualEncryptedBytes = oaepEncoding.ProcessBlock(plainBytes, 0, plainBytes.Length);

我想我不确定如何使用RSA公共字节构造RsaKeyParameters。有人可以指出我正确的方向吗?还是我在这里完全走错路了?

1 个答案:

答案 0 :(得分:1)

您使用了错误的PemReader,您想要的是Org.BouncyCastle.OpenSsl中的那个。

编辑:由于某种原因,OP坚持认为此类没有ReadObject方法。确实如此,可以看到here

赞:

using System;
using System.IO;
using Org.BouncyCastle.OpenSsl;
using Org.BouncyCastle.Security;

namespace ScratchPad
{
    class MainClass
    {
        public static void Main(string[] args)
        {
            var pemReader = new PemReader(File.OpenText(@"/Users/horton/tmp/key-examples/myserver_pub.pem"));
            var pemObject = (Org.BouncyCastle.Crypto.Parameters.RsaKeyParameters)pemReader.ReadObject();
            var rsa = DotNetUtilities.ToRSA(pemObject);
            // ... more stuff ...
        }
    }
}