Csharp/C#教程:C#RSACryptoServiceProvider:如何检查容器中是否已存在密钥?分享


C#RSACryptoServiceProvider:如何检查容器中是否已存在密钥?

我正在为多个客户端之间构建一个安全消息传递应用程序。 为了实现这一点,我使用AES加密消息,然后使用收件人公共RSA密钥加密AES密钥,然后将这两个组件(RSA加密的AES密钥和AES加密的消息)发送给收件人。 整个过程运作良好,没有任何错误。

现在我遇到了一个问题,我想知道什么是最好的做法:为了坚持一个adipent的私钥和公钥,我需要存储密钥对。 可以将它保存为某个XML文件,但显然不是一个选项。 所以决定使用这里描述的密钥容器。 实现容器的使用非常简单,但我怎么能

  1. 检查指定的容器是否已存在?
  2. 检查密钥大小是否与给定值匹配?

据我所知,这是不可能的,因为如果容器不存在,RSACryptoServiceProvider会生成一个新密钥 – 没有这么说。 但我需要知道是否有先前存储的密钥对可用,或者是否创建了新的密钥对。

我该如何解决这个问题? 或者这是一个完全错误的方法? 谢谢你的帮助!

问候,Rob

试试这个:

public static bool DoesKeyExists(string containerName) { var cspParams = new CspParameters { Flags = CspProviderFlags.UseExistingKey, KeyContainerName = containerName }; try { var provider = new RSACryptoServiceProvider(cspParams); } catch (Exception e) { return false; } return true; } 

类似的问题: 如何检查.NET中是否存在RSA密钥容器

上述就是C#学习教程:C#RSACryptoServiceProvider:如何检查容器中是否已存在密钥?分享的全部内容,如果对大家有所用处且需要了解更多关于C#学习教程,希望大家多多关注—计算机技术网(www.ctvol.com)!

本文来自网络收集,不代表计算机技术网立场,如涉及侵权请联系管理员删除。

ctvol管理联系方式QQ:251552304

本文章地址:https://www.ctvol.com/cdevelopment/998397.html

(0)
上一篇 2021年12月27日
下一篇 2021年12月27日

精彩推荐