我正在为多个客户端之间的安全消息传递构建应用程序。为了实现这一点,我使用AES加密消息,然后使用收件人公共RSA密钥加密AES密钥,然后将这两个组件(RSA加密的AES密钥和AES加密的消息)发送给收件人。整个过程运作良好,没有任何错误。
现在我遇到了一个问题,我想知道最佳做法是什么:为了保留一个adipent的私钥和公钥,我需要存储密钥对。可以将它保存为某个XML文件,但显然不是一个选项。因此决定使用密钥容器described here。实现容器的使用非常简单,但我怎么能
据我所知,这是不可能的,因为如果容器不存在,RSACryptoServiceProvider会生成一个新密钥 - 而不会这么说。但我需要知道是否有先前存储的密钥对可用,或者是否创建了新的密钥对。
我该如何解决?或者这是一种完全错误的做法?
答案 0 :(得分:4)
试试这个:
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;
}