`

http 500错误的处理方法

阅读更多

转自:http://baike.baidu.com/view/965448.htm

转自:http://hi.baidu.com/happyzhyq1984/blog/item/c0fd99a9df5c94f51f17a259.html

 

步骤:

1. 先从IE里读出具体错误信息(IE里设置一下);

2. 然后详细找原因;(找到错误根源后,按以下横线结束处的步骤即可解决)

 

Microsoft JET Database Engine (0x80004005) 未指定的错误的完美解决[转贴]
2009年07月16日 星期四 13:40
一般情况下asp可以正常运行,但只要连接数据库就提示,Microsoft JET Database Engine 错误

'80004005',我的电脑因为用批处理清理文件,所以不能运行了, 只
1.查看数据库连接语句没有发现错误;
2.查看文件夹的权限已经全部给了everyone;
3.打开数据库的同时,系统会在临时文件夹 %SystemRoot%/temp/ 下创建临时文件,而 %

SystemRoot%/temp/ 的权限不够
解决:%SystemRoot%/temp/ 的权限加上(IUSER_电脑名的读写)

 

--------------------------------------------------------------

 

 

HTTP-500错误

  http 500内部服务器错误说明IIS服务器无法解析ASP代码,访问一个静
  态页面试试是否也出现这个问题,如果访问静态页面没问题,那就要分以下几种
  情况来分析了:
  ① 你是否改变过计算机名称。
  ② 站点所在的文件目录是否自定义了安全属性。
  ③ 安装了域控制器后是否调整了域策略。如果是其中的一种情况,请一一将
  改变的参数设置回来看是否解决问题。
  如果静态空间也无法访问,则说明解析还没生效.
  首先你要确定错误的原因:
  让IE显示详细的出错信息:
  菜单--工具--Internet选项--高级--显示友好的HTTP错误信息,去掉这个选择吧
  ,然后刷新出错页,就可以看到详细的出错信息,对帮助你确定错误所在非常有
  帮助!
  造成500错误常见原因有:ASP语法出错、ACCESS数据库连接语句出错、文件引用
  与包含路径出错、使用了服务器不支持的组件如FSO等。
  另解释:
  xp下IIS5.1无法执行ASP文件,错误!500 内部服务器连接错误|解决方法
  原因分析
  综合分析上面的错误表现我们可以看出,主要是由于iwam账号(在我的计算机即是iwam_myserver账号)的密码错误造成了http 500内部错误。
  在详细分析http500内部错误产生的原因之前,先对iwam账号进行一下简要的介绍:iwam账号是安装iis5时系统自动建立的一个内置账号,主要用于启动进程之外的应用程序的internet信息服务。iwam账号的名字会根据每台计算机netbios名字的不同而有所不同,通用的格式是iwam_machine,即由“iwam”前缀、连接线“_”加上计算机的netbios名字组成。我的计算机的netbios名字是myserver,因此我的计算机上iwam账号的名字就是iwam_myserver,这一点与iis匿名账号isur_machine的命名方式非常相似。
  iwam账号建立后被active directory、iis metabase数据库和com+应用程序三方共同使用,账号密码被三方分别保存,并由操作系统负责这三方保存的iwam密码的同步工作。按常理说,由操作系统负责的工作我们大可放心,不必担心出错,但不知是bug还是其它什么原因,系统的对iwam账号的密码同步工作有时会失败,使三方iwam账号所用密码不统一。当iis或com+应用程序使用错误iwam的密码登录系统,启动iis out-of-process pooled applications时,系统会因密码错误而拒绝这一请求,导致iis out-of-process pooled applications启动失败,也就是我们在id10004错误事件中看到的“不能运行服务器 3d14228d-fbe1-11d0-995d-00c04fd919c1} ”(这里 3d14228d-fbe1-11d0-995d-00c04fd919c1} 是iis out-of-process pooled applications的key),不能转入iis5应用程序,http 500内部错误就这样产生了。
  三.解决办法
  知道了导致http 500内部错误的原因,解决起来就比较简单了,那就是人工同步iwam账号在active directory、iis metabase数据库和com+应用程序中的密码。
  具体操作分三步,均需要以管理员身份登录计算机以提供足够的操作权限(iwam账号以iwam_myserver为例)。
  (一)更改active directory中iwam_myserver账号的密码
  因iwam账号的密码由系统控制,随机产生,我们并不知道是什么,为完成下面两步的密码同步工作,我们必须将iwam账号的密码设置为一个我们知道的值。
  1、选择“开始”->“程序”->“管理工具”->"active directory用户和计算机",启动“active directory用户和计算机”管理单元。
  2、单击“user”,选中右面的“iwam_myserver”,右击选择“重设密码(t)...”,在跳出的重设密码对方框中给iwam_myserver设置新的密码,这儿我们设置成“aboutnt2001”(没有引号的),确定,等待密码修改成功。
  (二)同步iis metabase中iwam_myserver账号的密码
  可能因为这项改动太敏感和重要,微软并没有为我们修改iis metabase中iwam_myserver账号密码提供一个显式的用户接口,只随iis5提供了一个管理脚本adsutil.vbs,这个脚本位于c:\inetpub\adminscripts子目录下(位置可能会因你安装iis5时设置的不同而有所变动)。
  adsutil.vbs脚本功能强大,参数非常多且用法复杂,这里只提供使用这个脚本修改iwam_myserver账号密码的方法:
  adsutil set w3svc/wamuserpass password
  "password"参数就是要设置的iwam账号的新的密码。因此我们将iis metabase中iwam_myserver账号的密码修改为“aboutnt2001”的命令就是:
  c:\inetpub\adminscripts>adsutil set w3svc/wamuserpass "aboutnt2001"
  修改成功后,系统会有如下提示:
  wamuserpass: (string) "aboutnt2001"
  (三)同步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”->“属性”。
  (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程序又可以运行了!
  修改成功后,系统会有如下提示:
  ---------------------------------------------------
  经过测试,显示应该是
  wamuserpass: (string) "*******"
  http 500内部服务器错误可能和IIS 服务器无法加载应用程序有关具体是:
  现象:
  浏览ASP时 HTTP500内部错误
  [asp.net]解决IIS 服务器无法加载应用程序 '/LM/W3SVC/1/ROOT' 错误是 '没有注册类别
  查看了一下事件查看器:
  [1]:服务器无法加载应用程序 '/LM/W3SVC/1/ROOT'。错误是 '没有注册类别'。
  [2]:无法启动 MS DTC 事务管理器。
  [3]:MS DTC 事务管理器启动失败。LogInit 返回错误 0x2。。
  [4]: 找不到 MS DTC 日志文件。在确认所有由 MS DTC 协调的资源管理器不具有“不确定”状态的事务之后,请运行 msdtc -resetlog 创建日志文件。
  解决办法:
  
 [1]:检查你的DTC服务(Distributed Transaction Coordinator)是否可以正常启动,如果正常的话请你跳过此步骤;如果出错,无法正常启动,请在开始菜单的运行中 运行:msdtc -resetlog以创建日志文件。重起机器,检查IIS是否可以正常使用,若不行继续。
  [2]:在CMD(.bat)下执行以下命令:
  cd %windir%\system32\inetsrv
  rundll32 wamreg.dll, CreateIISPackage
  regsvr32 asptxn.dll
  重起电脑
  我到这里就已经解决问题了!(问题是漫漫发现的,需要一起解决)

 

 

 

 

----------------------------------------------------------------------------------------------------

 

 

 

 

 

Microsoft JET Database Engine (0x80004005) 未指定的错误的完美解决[转贴]
2009年07月16日 星期四 13:40

一般情况下asp可以正常运行,但只要连接数据库就提示,Microsoft JET Database Engine 错误

'80004005',我的电脑因为用批处理清理文件,所以不能运行了, 只
1.查看数据库连接语句没有发现错误;
2.查看文件夹的权限已经全部给了everyone;
3.打开数据库的同时,系统会在临时文件夹 %SystemRoot%/temp/ 下创建临时文件,而 %

SystemRoot%/temp/ 的权限不够
解决:%SystemRoot%/temp/ 的权限加上(IUSER_电脑名的读写)

 

(-----------------------------------------------------------------------------------------

   经检验,我只用以上三步,就解决了问题

)

 

更多内容参考: http://hi.baidu.com/cfscc


2、如果一般未指定的错误,还有个办法,先
其实只要很简单的几步。:
开始。。。运行。。。regsvr32 jscript.dll
开始。。。运行。。。regsvr32 vbscript.dll
开始。。。运行。。。iisreset

 

Microsoft JET Database Engine (0x80004005)未指定的错误解决
1、系统可能没有注册msjetoledb40.dll,解决办法是
   点 开始--->运行, 输入 regsvr32 msjetoledb40.dll, 回车即可;

2、数据库所在文件夹权限
   打开办法是:打开我的电脑,然后点菜单上的“文件夹选项”--->查看,然后把“使用简单文

件夹共享(推荐)”前面的钩去掉,然后点“确认”;接下来回到需要打开权限的文件夹(数据库存

放的文件夹),右键---> 属性--->安全,然后点“添加”--->"高级"--->立即查找--->然后在下面

的地方选择“everyone”--->确定--->点刚才加入的"everyone",然后在下面的大框编辑everyone

权限为完全控制,保存即可。


3、需要打开guest用户
   打开方法:我的电脑--->控制面板--->管理工具---->计算机管理--->本地用户和组---用户---

找到"guest",双击,然后把弹出来的狂上的“帐户已停用”前的钩去掉,保存即可。


4、temp(临时文件夹)权限
   打开办法:windows--->temp,单击右键选择-属性,你就会看到一个叫做“安全”的选项,添

加一个everyone,权限设置为完全控制,再将你正在使用windows的用户也设置为完全控制.(件夹权


   打开办法是:打开我的电脑,然后点菜单上的“文件夹选项”--->查看,然后把“使用简单文

件夹共享(推荐)”前面的钩去掉,然后点“确认”;接下来回到需要打开权限的文件夹(数据库存

放的文件夹),右键---> 属性--->安全,然后点“添加”--->"高级"--->立即查找--->然后在下面

的地方选择“everyone”--->确定--->点刚才加入的"everyone",然后在下面的大框编辑everyone

权限为完全控制,保存即可。

 


本人要用ASP批量导入excel数据到sql数据库去,借用了zhanghongwen(流氓蚊子)   的代码,如下

:  
...  
...  
...  
<%  
server.scripttimeout=100000000  
sub   dataIntoSqlServer_ceritificate(strFileName,strSheetName,myConn)  
          '定义  
          dim   myConnection  
          dim   strName  
          dim   rsXsl,rsSql  
          dim   str_Xsl,str_Sql  
          dim   myConn_Xsl  
          dim   cmd  
          dim   i,j  
          dim   maxId  
   
          strName=strFileName    
          set   myConnection=server.createobject("adodb.connection")  
          set   rsXsl=Server.Createobject("ADODB.Recordset")  
          set   rsSql=Server.CreateObject("ADODB.Recordset")  
          set   cmd=Server.CreateObject("ADODB.Command")  
cmd.ActiveConnection=myConn  
   
   
     
          myConn_Xsl="Provider=Microsoft.Jet.OLEDB.4.0;Data   Source="   &   strName  

&   ";Extended   Properties=Excel   8.0"    
   
     
        '打开连接  
          myConnection.open   myConn_Xsl  
     
          '打开表    
          str_Xsl="select   *   from   ["&   strSheetName   &"$]"  
          rsXsl.open   str_Xsl,myConnection,1,1    
j=1  
          Do   While   not   rsXsl.eof  
          '取出最大值  
          str_Sql="select   Max(id)   as   maxId   from   fubiao"  
          rsSql.open   str_Sql,myConn,1,3  
          If   Not   rsSql.Eof   Then  
                If   not   isNull(rsSql("maxId"))   Then  
                      maxId=Clng(rsSql("maxId"))+1  
          Else  
                maxId=1  
          End   if  
          else  
                maxId=1  
          End   if  
          rsSql.close'//关闭对象  
'加入数据库  
str_Sql="insert   into   fubiao   values("&maxId&",'"&rsXsl(1)&"','"&rsXsl(3)

&"','"&rsXsl(4)&"','"&rsXsl(5)&"','"&rsXsl(6)&"','"&rsXsl(7)&"','"&rsXsl(8)

&"','"&rsXsl(9)&"','"&rsXsl(10)&"','"&rsXsl(11)&"','"&rsXsl(12)&"','"&rsXsl(13)

&"','"&rsXsl(14)&"','"&rsXsl(15)&"','"&rsXsl(16)&"','"&rsXsl(17)&"','"&rsXsl(18)

&"','"&rsXsl(19)&"','"&rsXsl(20)&"','"&rsXsl(21)&"','"&rsXsl(22)&"','"&rsXsl(23)

&"','"&rsXsl(24)&"','"&rsXsl(25)&"','"&rsXsl(26)&"','"&rsXsl(27)&"')"    
          cmd.CommandText=str_Sql  
          cmd.Execute()                                                
                         

''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''

'''  
                    j=j+1  
          rsXsl.movenext    
          Loop  
   
          response.write   "共导入<font   color='red'>"   &   j-1   &   "</font>条记录

.<br/>"  
          response.write   "<a   href=javascript:history.back()>确定</a>"    
          set   rsXsl=nothing    
          set   rsSql=nothing  
          set   myconnection=nothing    
          set   cmd=nothing    
end   sub  
...  
...  
...  
file1=request.form("filename2")  
strtj=mid(request.form("filename2"),instrrev(file1,"\")+1,(instrrev(file1,".")-

instrrev(file1,"\")-1))    
if   file1=""   then  
    response.write   "请选择您要导入的Excel表!<p></p>"      
%>  
<a   href=javascript:history.back()>上一页</a>  
<%  
          response.end  
        end   if  
myconn="DRIVER={SQL   SERVER};SERVER=(local);uid=sa;pwd=sa;DATABASE=qjgsj_data"  
call   dataIntoSqlServer_ceritificate     file1,""&strtj&"",myconn  
...  
...  
%>  
在打开连接时:  
myConnection.open   myConn_Xsl  
   
出现:HTTP 500.100_内部服务器错误_ASP错误  
错误类型:  
Microsoft   Jet   Database   Engine(0x80004005)  
\..\..\aa.asp   xx行  
是什么问题呢?  
此连接句有问题吗?  
        myConn_Xsl="Provider=Microsoft.Jet.OLEDB.4.0;Data   Source="   &   strName   &

";Extended   Properties=Excel   8.0"    
   
我服务器系统DSN已给SQL数据库建立了数据源,用ASP批量导入EXCEL数据,还需在系统DSN给

EXCEL设置驱动程序吗?  
zhanghongwen(流氓蚊子)在吗? 问题点数:80、回复次数:4Top

1 楼VeryOldMan(无头苍蝇(www.gzmeishi.com))回复于 2006-01-27 14:53:46 得分

80myConn_Xsl="Provider=Microsoft.Jet.OLEDB.4.0;Data   Source="   &   Server.MapPath

("/yourexcel.xls")   _  
                &   ";Extended   Properties=""Excel   8.0;HDR=Yes;"";"    
SQL   Command:     "Select   *   From   [yourSheetname$]"  
   
在我自己的网站:www.gzmeishi.com上测试通过!Top

2 楼zcxc(知春小草)回复于 2006-02-05 14:18:59 得分 0 还是不行。  
Microsoft.Jet.OLEDB.4.0在服务器上需要配置吗?Top

3 楼zcxc(知春小草)回复于 2006-02-05 18:36:27 得分 0 郁闷!!!  
请高手相助!!!  
我服务器配置为windows   server   2000,iis   5.0,sql   server   2000。  
用myConn_Xsl="Provider=Microsoft.Jet.OLEDB.4.0;Data   Source="   &   strName   &  

";Extended   Properties=Excel   8.0"    
或myConn_Xsl="Provider=Microsoft.Jet.OLEDB.4.0;Data   Source="   &   Server.MapPath

("strName   ")   _  
                &   ";Extended   Properties=""Excel   8.0;HDR=Yes;"";"   语句  
打开该连接时出现错误:  
Microsoft   Jet   Database   Engine(0x80004005)  
/../../aa.asp   xx行  
   
用myconn_Xsl="driver={microsoft   excel   driver(*.xls)};dbq="&server.mappath

("strName")  
来连接时打开则出现错误:  
microsoft   ole   db   provider   for   odbc   drivers(0x80004005)  
/../../aa.asp   xx行  
   
请问:  
用myconn_Xsl="driver={microsoft   excel   driver(*.xls)};dbq="&server.mappath

("strName")语句来连接时,服务器该如何配置?  
用myConn_Xsl="Provider=Microsoft.Jet.OLEDB.4.0;Data   Source="   &   strName   &  

";Extended   Properties=Excel   8.0"    
或myConn_Xsl="Provider=Microsoft.Jet.OLEDB.4.0;Data   Source="   &   Server.MapPath

("strName   ")   _  
                &   ";Extended   Properties=""Excel   8.0;HDR=Yes;"";"    
来连接,服务器又该如何配置?  
出现上述问题,是什么原因?是服务器缺少什么配置或其他什么的?  
请高手指点一下。  

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics