前几天做网站时,机子出现了这种症状,重装过IE和IIS一样也无法解决,在百度里找了一下,下面的方法真的很适用。
症状:运行asp程序(包括其他动态网页程序)出现500内部错误信息,但是HTML网页却能正常运行。
一、现象描述:
本地运行asp文件,IE提示:
Server Application Error
The server has encountered an error while loading an application during the processing of your request. Please refer to the event log for more detail information. Please contact the server administrator for assistance.
查看日志文件:
系统日志具体描述如下:
DCOM 错误 无 10010 NT AUTHORITY/SYSTEM Myserver 服务器 {3D14228D-FBE1-11D0-995D-00C04FD919C1} 没有在限定的时间内用 DCOM 注册。
W3SVC 警告 无 36 N/A Myserver 服务器未能转入应用程序 '/LM/W3SVC/1/Root'。错误是 '服务器运行失败 '。
若要获取关于此消息的更多的信息,请访问 Microsoft 联机支持站点: http://www.microsoft.com/contentredirect.asp 。
应用程序日志具体描述如下:
COM+ 错误 管理 4205 N/A Myserver 由于在下列系统 API 错误,COM+ 服务无法初始化。它通常是由本地计算机的系统资源存储问题引起的。
CryptAcquireContext
进程名称: dllhost.exe
该错误的严重性已导致进程终止。
错误代码= 0x80090017 : 提供程序类型未被定义。
COM+ 服务内部信息:
文件: ./security.cpp, 行: 617
二、原因分析
曾经删除过SA,SAM文件是保存用户密码的数据库文件,删除后,所有的用户信息就会丢失,而相应的组信息也会随之丢失,虽然重新登录过系统,系统已经重新建立了SAM文件,也重新安装了IIS,IWAM帐号也已经重新建立,但是,原用户组中的特殊信息却没有被恢复。
检查“开始”->“设置”->“控制面板”->“管理工具”->“组件服务”中,“控制台根目录”->“组件服务”->“计算机”->“我的电脑”->“COM+应用程序”中,有一个IIS Out-Of-Process Pooled Applications该应用程序的ID号即为{3D14228D-FBE1-11D0-995D-00C04FD919C1},很多系统报错找不到应用程序{3D14228D-FBE1-11D0-995D-00
C04FD919C1}之类的错误,就是因为该应用程序未能启动,打开该应用程序的属性,检查标识却为IWAM用户,右键启动,报错。改为管理员后,可正常启动。把IWAM加入本地管理员组中,也可正常启动。确定是因为IWAM用户无权访问该应用程序所致。
三、解决办法
1、修改IWAM_Myserver帐号密码,在“开始”->“设置”->“控制面板”->“管理工具”->“计算机管理”中,“系统工具”->“本地用户和组”->“用户”里面,一个IWAM_Myserver(Myserver为本地计算机名)的帐号内,右键更改密码,更改为一个自定义的密码即可,假设为“1234”;
2、修改IIS内部IWAM_Myserver帐号密码,在c:/inetpub/adminscripts/目录下(IIS安装默认目录),输入:c:/inetpub/adminscripts>adsutil.vbs set w3svc/wamuserpass "1234" .修改成功后,系统有如下提示wamuserpass: (string) "******"
3、在“开始”->“设置”->“控制面板”->“管理工具”->“计算机管理”中,“系统工具”->“本地用户和组”->“用户”里面,确认IWAM_My server用户只在GUEST组内,再在“本地用户和组”->“组”里面,右键点击Users组属性,添加进NT AUTHORITY/Authenticated Users和NT AUTHORITY/Interactive两个用户成员,确定。
4、在IIS安装默认目录下输入:c:/inetpub/adminscripts>synciwam.vbs -v
将COM+程序的用户改回为IWAM用户,重新启动IIS Out-Of-Process Pooled Applications应用程序,没有再报错了,再重启IIS,检查所有WEB站点服务,故障现象解除!
同步COM+应用程序所用的IWAM_MYSERVER的密码
同步COM+应用程序所用的IWAM_MYSERVER的密码,我们有两种方式可以选择:一种是使用组件服务MMC管理单元,另一种是使用IWAM账号同步脚本synciwam.vbs。
1、使用组件服务MMC管理单元
(1)启动组件服务管理单元:选择"开始"->"运行"->"MMC",启动管理控制台,打开"添加/删除管理单元"对话框,将"组件服务"管理单元添加上。
(2)找到"组件服务"->"计算机"->"我的电脑"->"COM+应用程序"->"Out-Of-Process Pooled Applications",右击"Out-Of-Process Pooled Applications"->"属性"。
同步COM+应用程序所用的IWAM_MYSERVER的密码
同步COM+应用程序所用的IWAM_MYSERVER的密码,我们有两种方式可以选择:一种是使用组件服务MMC管理单元,另一种是使用IWAM账号同步脚本synciwam.vbs。
1、使用组件服务MMC管理单元
(1)启动组件服务管理单元:选择"开始"->"运行"->"MMC",启动管理控制台,打开"添加/删除管理单元"对话框,将"组件服务"管理单元添加上。
(2)找到"组件服务"->"计算机"->"我的电脑"->"COM+应用程序"->"Out-Of-Process Pooled Applications",右击"Out-Of-Process Pooled Applications"->"属性"。
解决IIS的Server Application Error办法 |
Server Application Error The server has encountered an error while loading an application during the processing of your request. Please refer to the event log for more detail information. Please contact the server administrator for assistance. ------------------------------------ 1。右键我的电脑--管理--本地用户和组,给IUSR_机器名和IWAM_机器名两个用户设置密码,要一样。 2。开始--运行--输入cmd, 然后cd c:/Inetpub/AdminScripts 然后cscript.exe adsutil.vbs set w3svc/wamuserpass 你的密码, 然后cscript.exe adsutil.vbs set w3svc/anonymoususerpass 你的密码 看一下,行了没有?如果还不行,那么 cscript.exe synciwam.vbs -v, 然后iisreset |
同步COM+应用程序所用的IWAM_MYSERVER的密码
同步COM+应用程序所用的IWAM_MYSERVER的密码,我们有两种方式可以选择:一种是使用组件服务MMC管理单元,另一种是使用IWAM账号同步脚本synciwam.vbs。
(三)同步COM+应用程序所用的IWAM_MYSERVER的密码
同步COM+应用程序所用的IWAM_MYSERVER的密码,我们有两种方式可以选择:一种是使用组件服务MMC管理单元,另一种是使用IWAM账号同步脚本synciwam.vbs。
1、使用组件服务MMC管理单元
(1)启动组件服务管理单元:选择"开始"->"运行"->"MMC",启动管理控制台,打开"添加/删除管理单元"对话框,将"组件服务"管理单元添加上。
(2)找到"组件服务"->"计算机"->"我的电脑"->"COM+应用程序"->"Out-Of-Process Pooled Applications",右击"Out-Of-Process Pooled Applications"->"属性"。
...............注意:当双击COM+应用程 若出现编录错误对话时按以下作:.......................................
从管理工具>组件服务>计算机>我的电脑>COM+应用程序,当我双击"COM+应用程序"时, 执行最后操作时发生错误。错误代码:8004EooF - COM+无法与Microsoft分布式事务协调程序交谈。
Step1 停止MSDTC服务:net stop msdtc
Step2 卸载MSDTC服务:msdtc -uninstall Step3 重新安装MSDTC服务:msdtc -install
....................................................................................................................................................
(3)切换到"Out-Of-Process Pooled Applications"属性对话框的"标志"选项卡。"此应用程序在下列账户下运行"选择中"此用户"会被选中,用户名是"IWAM_MYSERVER"。这些都是缺省的,不必改动。在下面的"密码"和"确认密码"文本框内输入正确的密码"Aboutnt2001",确定退出。
(4)系统如果提示"应用程序被一个以上的外部产品创建。你确定要被这些产品支持吗?"时确定即可。
(5)如果我们在IIS中将其它一些Web的"应用程序保护"设置为"高(独立的)",那么这个WEB所使用的COM+应用程序的IWAM账号密码也需要同步。重复(1)-(4)步,同步其它相应Out of process application的IWAM账号密码。
2、使用IWAM账号同步脚本synciwam.vbs
实际上微软已经发现IWAM账号在密码同步方面存在问题,因此在IIS5的管理脚本中单独为IWAM账号密码同步编写了一个脚本synciwam.vbs,这个脚本位于C:/inetpub/adminscripts子目录下(位置可能会因你安装IIS5时设置的不同而有所变动)。
synciwam.vbs脚本用法比较简单:
cscript synciwam.vbs [-v|-h]
"-v"参数表示详细显示脚本执行的整个过程(建议使用),"-h"参数用于显示简单的帮助信息。
我们要同步IWAM_MYSERVER账号在COM+应用程序中的密码,只需要执行"cscript synciwam.vbs -v"即可,如下:
cscript c:/inetpub/adminscripts/synciwam.vbs -v
Microsoft (R) Windows Script Host Version 5.6
版权所有(C) Microsoft Corporation 1996-2000。保留所有权利。
WamUserName:IWAM_MYSERVER
WamUserPass:Aboutnt2001
IIS Applications Defined:
Name, AppIsolated, Package ID
w3svc, 0, {3D14228C-FBE1-11d0-995D-00C04FD919C1}
Root, 2,
IISHelp, 2,
IISAdmin, 2,
IISSamples, 2,
MSADC, 2,
ROOT, 2,
IISAdmin, 2,
IISHelp, 2,
Root, 2,
Root, 2,
Out of process applications defined:
Count: 1
{3D14228D-FBE1-11d0-995D-00C04FD919C1}
Updating Applications:
Name: IIS Out-Of-Process Pooled Applications Key: {3D14228D-FBE1-11D0-995D-00C04FD919C1}
从上面脚本的执行情况可以看出,使用synciwam.vbs脚本要比使用组件服务的方法更全面和快捷。它首先从IIS的metabase数据库找到IWAM账号"IWAM_MYSERVER"并取出对应的密码"Aboutnt2001",然后查找所有已定义的IIS Applications和Out of process applications,并逐一同步每一个Out of process applications应用程序的IWAM账号密码。
使用synciwam.vbs脚本时,要注意一个问题,那就是在你运行synciwam.vbs之前,必须保证IIS metabase数据库与Active Directory中的IWAM密码已经一致。因为synciwam.vbs脚本是从IIS metabase数据库而不是从Active Directory取得IWAM账号的密码,如果IIS metabase中的密码不正确,那synciwam.vbs取得的密码也会不正确,同步操作执行到"Updating Applications"系统就会报80110414错误,即"找不到应用程序{3D14228D-FBE1-11D0-995D-00C04FD919C1}"。
好了,到现在为止,IWAM账号在Active Directory、IIS metabase数据库和COM+应用程序三处的密码已经同步成功,你的ASP程序又可以运行了!
HTTP内部500错误,查看日志报MSDTC错误
系统为xp sp2 asp文件不能访问,报HTTP内部500错误,打开IE》工具》INTERNET选项》高级》把显示友好HTTP错误信息前的勾去掉,确定。然后再打开你的程序,就会出现具体的错误,报:Server Application Error The server has encountered an error while loading an application during the processing of your request. Please refer to the event log for more detail information. Please contact the server administrator for assistance. HTM可以访问,查看日志见很多MSDTC服务和设备的错误, 本以为是帐户不同步引起的,于是按如下步骤来同步密码: 具体解决方法如下: 1.右键我的电脑--管理--本地用户和组,给IUSR_机器名和IWAM_机器名两个用户设置密码,要一样。 2.开始--运行--打cmd, 然后cd C:/Inetpub/AdminScripts 然后cscript.exe adsutil.vbs set w3svc/wamuserpass 你的密码, 然后cscript.exe adsutil.vbs set w3svc/anonymoususerpass 你的密码 看一下,行了没有?如果还不行,那么: cscript.exe synciwam.vbs -v, 然后iisreset。 但是在同步帐户最后一步: cscript.exe synciwam.vbs -v 时有如下错误: Out of process applications defined: Count: 1 {3D14228D-FBE1-11d0-995D-00C04FD919C1} Error: 8004E00F: 这时想起了COM+应用程序可能出问题,于是:打开:控制面板---》管理工具---组件服务,发现“我的电脑”有红色小尖头,再 点击组件服务里“com+应用程序”的时候,提示: 执行最后操作时发生错误. 错误代码80080005 - 服务器运行失败 事件日志可能包含其他疑难解答信息 上网找了一下解决方法, cd %systemroot%/system32 msdtc -uninstall msdtc -install 命令执行过后,果然可以同步帐户最后一步: cscript.exe synciwam.vbs -v,然后重启IIS,ASP页面又可以正常访问了。 最后想了一下,如果早些看日志,直接在网上搜索MSDTC服务和设备错误,可能更快的找到问题所在。 于是:直接查找MSDTC错误,果然能直接找到解决方法: 关于http500错误及报8004e00f的解决方法 IIS不正常,http500错误,无法解析asp文件 原因:发现MSDTC服务不正常,具体的解决方法如下: 1、首先进入组件服务,查看组件服务/计算机/我的电脑/COM+应用程序,结果报错“COM+ 无法与 Microsoft 分布式事务协调程序交谈”,无法查看里面的对象。 2、进入事件查看器,发现msdtc服务没有正常启动。 3、删除注册表中的键: • HKEY_LOCAL_MACHINE/SYSTEM/CurrentControlSet/Services/MSDTC • HKEY_LOCAL_MACHINE/SOFTWARE/Microsoft/MSDTC • HKEY_CLASSES_ROOT/CID 4、停止MSDTC服务:net stop msdtc 5、卸载MSDTC服务:msdtc -uninstall 6、重新安装MSDTC服务:msdtc -install 7、确认在事件查看器中msdtc服务已经正常启动[这步很关键,如果没有,重新启动下电脑看看] 8、重新设置IIS的IWAM账号密码。[在计算机管理中的用户管理里] 9、同步IIS metabase中IWAM_MYSERVER的密码,在CMD中:c:/inetput/adminscripts>adsutil set w3svc/wamuserpass "yourpassword" 10、同步COM+应用程序所用的IWAM_MYSERVER密码,在CMD中:c:/inetput/adminscripts>cscript synciwam.vbs -v |
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)