c# - 从公钥(不是证书)构建 RSACryptoServiceProvider

标签 c# rsa x509certificate encryption-asymmetric

我正在开展一个项目,我需要使用“公钥”通过 RSA 算法加密消息。我获得了一个证书,我的第一个想法是使用该证书中的公钥,经过调查我了解到我需要使用 RSACryptoServiceProvider 进行加密。

我检查了 msdn,我认为我应该使用的唯一方法是 RSACryptoServiceProvider.ImportCspBlob(byte[] keyBlob)。 当我尝试使用从证书导出的公钥时,出现错误,指出证书的 header 数据无效。

我知道我可以将 X509certificate2.PublicKey.Key 转换为 RSACryptoServiceProvider 但据我从客户那里了解到,今后我将只获得一个公钥和不是证书。此 key 必须保存在 .xml 配置文件中。

总结一下:有没有办法只给证书的公钥生成 RSACryptoServiceProvider

最佳答案

你可以试试看这个例子:RSA public key encryption in C#

var publicKey = "<RSAKeyValue><Modulus>21wEnTU+mcD2w0Lfo1Gv4rtcSWsQJQTNa6gio05AOkV/Er9w3Y13Ddo5wGtjJ19402S71HUeN0vbKILLJdRSES5MHSdJPSVrOqdrll/vLXxDxWs/U0UT1c8u6k/Ogx9hTtZxYwoeYqdhDblof3E75d9n2F0Zvf6iTb4cI7j6fMs=</Modulus><Exponent>AQAB</Exponent></RSAKeyValue>";

var testData = Encoding.UTF8.GetBytes("testing");

using ( var rsa = new RSACryptoServiceProvider(1024))
{
    try
    {
        // client encrypting data with public key issued by server
        //
        rsa.FromXmlString(publicKey);
        var encryptedData = rsa.Encrypt(testData, true);

        var base64Encrypted = Convert.ToBase64String(encryptedData);

    }
    finally
    {
        rsa.PersistKeyInCsp = false;
    }
}

关于c# - 从公钥(不是证书)构建 RSACryptoServiceProvider,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15964980/

相关文章:

c# - 将 jqGrid 与 Asp.Net Web 窗体一起使用

encryption - 在PKCS#1 OAEP加密/解密中交换公钥/私钥

encryption - SHA1 与 RSA : what's the difference between them?

x509certificate - 授予帐户 NT Authority\Network Service 的私钥访问权限

x509certificate - 如何从 .NET 标准的 PEM 文件中加载带有私钥的证书

c# - 数据绑定(bind)到 WinForm

c# - 使用证书签署文件

c# - 访问 UserControl 中的主窗口控件

java - Windows上使用openssl C++的RSA加密/解密错误

c# - BouncyCaSTLe PrivateKey 到 X509Certificate2 PrivateKey