27

当更新我的 IIS 进程的实例时,它X509Certificate2(string, string)只会崩溃。没有 .Net 异常,什么都没有,除了我的事件日志中的这个

Faulting application name: w3wp.exe, version: 8.0.9200.16384, time stamp: 0x50108835
Faulting module name: ntdll.dll, version: 6.2.9200.16420, time stamp: 0x505ab405
Exception code: 0xc0000374
Fault offset: 0x00000000000ea485
Faulting process id: 0x102c
Faulting application start time: 0x01ce10301e250c4d
Faulting application path: c:\windows\system32\inetsrv\w3wp.exe
Faulting module path: C:\Windows\SYSTEM32\ntdll.dll
Report Id: 5e55321c-7c23-11e2-93f9-00155d8a0f17
Faulting package full name: 

我很震惊,不知道从哪里开始寻找。将调试器附加到进程时,我可以中断这一行,但是当跨过它时,整个事情都会崩溃。

_certificate = new X509Certificate2(pfxFile, pfxPassword);

pfxFile 是一个有效路径,如果我更改它,我会立即得到一个正确的 .Net PathNotFound 异常。

服务器是 Windows 2012,运行 IIS8 和 .Net 4.5。

更新
本文描述了相同的问题,解决方案是确保 App Pool 身份启用了LoadUserProfile 。

4

1 回答 1

37

我有一个类似的问题,也在 Windows Server 2012 上,它在使用时崩溃了 IIS

new X509Certificate2(fileName, keyPassword, X509KeyStorageFlags.Exportable)

这已通过将构造函数更改为

new X509Certificate2(fileName, keyPassword, X509KeyStorageFlags.MachineKeySet | X509KeyStorageFlags.PersistKeySet | X509KeyStorageFlags.Exportable)
于 2013-05-21T09:46:16.493 回答