如何检查容器中是否已存在密钥?

Rob*_*ert 5 .net c# containers key rsacryptoserviceprovider

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

现在我遇到了一个问题,我想知道最佳实践是什么:为了保留一个参与者的私钥和公钥,我需要存储密钥对。可以将其另存为XML文件,但这显然不是一种选择。因此决定使用此处描述的密钥容器。实现容器的使用非常容易,但是我该如何

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

据我所知,这是不可能的,因为如果容器不存在,则RSACryptoServiceProvider会生成一个新密钥-无需告知。但是我需要知道是否存在以前存储的密钥对,或者是否创建了新的密钥对。

我该如何解决?还是这是完全错误的方法?

dhc*_*cgn 6

尝试这个:

    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;
    }
Run Code Online (Sandbox Code Playgroud)

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