Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/csharp/301.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/.net/23.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
C# 如何检查容器中是否已经存在密钥?_C#_.net_Key_Containers_Rsacryptoserviceprovider - Fatal编程技术网

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

C# 如何检查容器中是否已经存在密钥?,c#,.net,key,containers,rsacryptoserviceprovider,C#,.net,Key,Containers,Rsacryptoserviceprovider,我正在为多个客户端之间的安全消息传递构建一个应用程序。为了实现这一点,我用AES加密消息,然后用收件人的RSA公钥加密AES密钥,然后将这两个组件(RSA加密的AES密钥和AES加密的消息)发送给收件人。整个过程运行良好,没有任何错误 现在我遇到了一个问题,我想知道最好的做法是什么:为了保存一个participent的私钥和公钥,我需要存储密钥对。将其保存为XML文件是可能的,但显然不是一种选择。所以决定使用密钥容器作为。实现容器的使用非常简单,但是如何实现呢 检查指定的容器是否已存在 检查键大

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

现在我遇到了一个问题,我想知道最好的做法是什么:为了保存一个participent的私钥和公钥,我需要存储密钥对。将其保存为XML文件是可能的,但显然不是一种选择。所以决定使用密钥容器作为。实现容器的使用非常简单,但是如何实现呢

  • 检查指定的容器是否已存在
  • 检查键大小是否与给定值匹配
  • 就我所知,这是不可能的,因为如果容器不存在,rsacyptoserviceprovider会生成一个新的密钥,而不告诉它。但我需要知道是否有以前存储的密钥对可用,或者是否创建了新的密钥对

    我怎样才能解决这个问题?或者这是一种完全错误的方法?

    尝试以下方法:

        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;
        }
    

    类似的问题:

    谢谢你的回答,它很有效。但自7月份以来,情况发生了变化-我不再信任此机制。请不要忘记在实例化它之后调用
    provider.Dispose()
    。在离开作用域之后是否会调用它?