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。有人可以指出我正确的方向吗?还是我在这里完全走错路了?
答案 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 ...
}
}
}