检查现有的RSA密钥容器

本文关键字:密钥 RSA 检查 | 更新日期: 2023-09-27 18:25:35

我使用以下代码创建了一个RSA密钥容器。密钥是在容器中创建的,我可以在容器中成功加密/解密。

public static void CreateKeyContainer()
    {
        RSACryptoServiceProvider rsa = null;
        try
        {
            var cryptoParameters = new CspParameters();
            cryptoParameters.KeyContainerName = "MyContainer";
            cryptoParameters.Flags = CspProviderFlags.UseMachineKeyStore;
            rsa = new RSACryptoServiceProvider(2048, cryptoParameters);
        }
        finally
        {
            if (rsa != null)
            {
                rsa.Clear();
                rsa.Dispose();
            }
        }
    }

在调用CreateKeyContainer方法之前,我想确保键是否已经存在于指定的容器中。我已将标志更改为CpsProviderFlags.UseExistingKey.

public static bool CheckIfKeysExist()
    {
        RSACryptoServiceProvider rsa = null;
        try
        {
            var cryptoParameters = new CspParameters();
            cryptoParameters.KeyContainerName = "MyContainer";
            cryptoParameters.Flags = CspProviderFlags.UseExistingKey;
            rsa = new RSACryptoServiceProvider(2048, cryptoParameters);
        }
        catch (Exception ex)
        {
            return false;
        }
        finally
        {
            if (rsa != null)
            {
                rsa.Clear();
                rsa.Dispose();
            }
        }
        return true;
    }

然而,通过执行此方法,它总是抛出一个Cryptographic Exception,即"密钥集不存在",而不管密钥容器是否存在。

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

检查现有的RSA密钥容器

由于您正在机器密钥存储中创建密钥,请设置Flags属性,如下所示:

cryptoParameters.Flags = CspProviderFlags.UseExistingKey | | CspProviderFlags.UseMachineKeyStore;