重装系统后,因为刚拿到一个oracle9.2的正版软件,一时高兴就装上了。可是发现项目不能用了,出现以下异常:System.Web.Services.Protocols.SoapException: 服务器无法处理请求。 ---> System.InvalidOperationException: 未在本地计算机上注册“OraOLEDB.Oracle”提供程序。 ---> System.Data.OleDb.OleDbException: 没有可用的错误信息: REGDB_E_CLASSNOTREG(0x80040154)。
--- 内部异常堆栈跟踪的结尾 ---
at XXX.DataAccess.DBO.GetDataAdapter(String sql) in D:/development/项目/XXX/源程序/XXXSolution/XXXService/DataAccess/DBO.cs:line 190
at XXX.DataAccess.DBO.ExecuteScalar(String sql) in D:/development/项目/XXX/源程序/XXXSolution/XXXService/DataAccess/DBO.cs:line 227
at XXX.DataAccess.LoginDBO.GetUserOrgNo(String userID, String password) in D:/development/项目/XXX/源程序/XXXSolution/XXXService/Login/LoginDBO.cs:line 32
at XXX.Business.BusinessObject.LoginBO.GetUserOrgNo(String userID, String password) in D:/development/项目/XXX/源程序/XXXSolution/XXXService/Login/LoginBO.cs:line 25
at XXX.Business.WebService.LoginWS.GetUserOrgNo(String userID, String password) in c:/inetpub/wwwroot/XXXWebService/LoginWS.asmx.cs:line 60
在网上找到一篇解决The 'OraOLEDB.Oracle.1' provider is not registered on the local machine的文章解决了这个问题,原文请参考:http://www.cnblogs.com/tongzhenhua/archive/2004/06/18/16714.html
解决方法如下:
到ORACLE_HOME目录,如c:/Oracle/Ora92
点击鼠标右键->属性->安全,
对ASP.NET 帐户赋予允许读、执行权限,并在“高级”中保证该目录的子目录、文件都继承这些属性,确定。
如果有Autoenticated Users,也同样赋予权限。
再次启动项目就可以正常运行了。不知是否还有别的方法?
补充:以后再装系统时,直接使用Fat32格式化要装Oracle的分区,就没有再出现此类问题。