gpt4 book ai didi

c# - C# 中来自智能卡的证书

转载 作者:太空狗 更新时间:2023-10-29 23:19:41 24 4
gpt4 key购买 nike

如何确保我从我的智能卡访问证书而不是在 c# 中形成我的个人证书存储?以及如何让我的 RSACryptoProvider 使用我的智能卡证书私钥?

谢谢

沃利

最佳答案

有时,特别是如果您没有使用智能卡上的默认 key 容器名称(Microsoft 推荐),证书不会复制到本地证书存储区。解决方案是使用加密 api 通过 KP_CERTIFICATE 访问 key ,从检索到的数据构造证书,并为其分配一个使用您自己的 key 容器名称构造的新 RSACryptoServiceProvider。

伪C#代码如下:

int reti = CryptoApi.CryptGetUserKey(_hprovider, keytype, ref userKey);

if (reti)
{
reti =CryptoApi.CryptGetKeyParam(_userKey, KP_CERTIFICATE, ref pbdata, ref pwddatalen, 0);
}

if (reti || pwddatalen>0)
{
byte[] data = new byte[pwddatalen];
ret = CryptoApi.CryptGetKeyParam(_userKey, KP_CERTIFICATE, data, ref pwddatalen, 0);
if (ret)
{
X509Certificate2 c = new X509Certificate2(data);
X509Store store = new X509Store(StoreName.My, StoreLocation.CurrentUser);
store.Open(OpenFlags.ReadOnly);
X509Certificate2Collection col = store.Certificates.Find(X509FindType.FindByThumbprint, c.Thumbprint, validonly);
store.Close();

if (col.Count != 1)
{
//not found in store - CSP didn't copy it
c.PrivateKey = PrivateKey(keytype);
return c;
}
else
{
return col[0];
}
}
}


private RSACryptoServiceProvider PrivateKey (KeyType keytype)
{
CspParameters csparms = new CspParameters();
csparms.KeyContainerName = _containerName;
csparms.ProviderName = _provider;
csparms.ProviderType = 1;
csparms.Flags = CspProviderFlags.UseMachineKeyStore | CspProviderFlags.UseExistingKey;
csparms.KeyNumber = (int)keytype;

return new RSACryptoServiceProvider(csparms);
}

关于c# - C# 中来自智能卡的证书,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/566179/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com