var cert = new X509Certificate2(certificateContent,// byte[] password,// string X509KeyStorageFlags.PersistKeySet);
certificateContent是一个表示pfx文件内容的byte [].此代码适用于我测试过的许多证书.但是,我正在测试的一个证书会导致此行抛出CryptographicException,并显示消息“指定的网络密码不正确.”,即使提供的密码是正确的.
奇怪的是,我可以在LinqPad中使用相同的代码从相同的pfx文件创建具有相同密码的证书,并且它可以正常工作.
我在调试器中检查了控制台应用程序中的调用站点,并验证了正在传入的值.
什么可能导致此构造函数在控制台应用程序中抛出此异常,但在LinqPad中不使用相同的数据,并且在其他证书的两个位置都可以正常工作?
更多细节
证书存储在Base64的数据库中. Console应用程序从DB读取证书,将其从Base64转换为byte [],然后尝试如上所述创建X509Certificate2对象.
我一直在测试三种证书:
>我的雇主CA提供的个人客户身份验证证书.
>由同事使用自己的自签名CA创建的测试证书.
>我自己使用自签名CA创建的测试证书.
证书1和2在控制台应用程序和LinqPad中按预期工作.
证书3在LinqPad中加载正常,但如果我尝试在控制台应用程序中使用它,则会生成上述错误.
证书2和证书之间存在两个显着差异. 3.
> Cert2于2016年到期,Cert3于2039年到期
>与cert2关联的私钥是2048位. Cert3是1024位.
这些差异中的任何一个都会导致“指定的网络密码不正确”错误吗?为什么所有3个证书在LinqPad中都可以正常工作,但只有1个在控制台应用程序中抛出错误?
解决方法
User “S C”指出了Windows XP和Windows Server 2003上的证书密码的以下要求.
0 < password.Length < 32
我看到有关32是否被允许的相互矛盾的报道.我可以确认我使用的是32个字符的密码(MD5哈希),并将其截断为30个字符来解决问题.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。