• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

Internal.Cryptography.CryptoThrowHelper+WindowsCryptographicException拒绝访问/出 ...

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

环境:iis/netcore 2.2 

初始调用:X509Certificate2 certificate = new X509Certificate2(input.Path, CER_PASSWORD);

参考链接:https://stackoverflow.com/questions/1345262/an-internal-error-occurred-when-loading-pfx-file-with-x509certificate2

相关译文:

MachineKeySet被描述为“私钥存储在本地计算机存储中而不是当前用户存储”。没有标志的默认值是放在用户存储中。

即使您正在从磁盘读取证书并将其存储在对象中,私钥仍存储在Microsoft Cryptographic API加密服务提供程序密钥数据库中。在托管服务器上,ASP.NET进程没有访问用户存储的权限。

有两个可能原因(我两个问题都遇到了):

1.权限不足

解决办法:提升程序池权限为LocalSystem,如下图

2.秘钥没有读取到,提示:出现了内部错误

修改了X509Certificate2声明后,提示“权限不足”,X509Certificate2如下声明:

   X509Certificate2 certificate = new X509Certificate2(input.Path, CER_PASSWORD, X509KeyStorageFlags.PersistKeySet | X509KeyStorageFlags.MachineKeySet);

然后按照,第一种解决方法即可。

 

PS:注意没有安装证书的,需要先双击证书文件


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
ASP.NET2.0(C#)实现多文件上传发布时间:2022-07-10
下一篇:
C#与数据库访问技术总结(七)综合示例发布时间:2022-07-10
热门推荐
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap