检查现有的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,即"密钥集不存在",而不管密钥容器是否存在。
如何检查密钥容器是否已经存在?
由于您正在机器密钥存储中创建密钥,请设置Flags属性,如下所示:
cryptoParameters.Flags = CspProviderFlags.UseExistingKey | | CspProviderFlags.UseMachineKeyStore;