在iis下发布eworkflow+eform+ebiao的代码,访问oracle的数据库,用oracleClient或者oledb的方式链接,有时会报“System.Data.OracleClient 须要 Oracle 客户端软件 8.1.7 或更高版本。 ”的错误,没法建立OracleConnection
缘由:
Oracle 9.2运行在NTFS的分区上时,对于某些非administrator组的用户,ORACLE_HOME 目录是不可见的,而在windows server 2003或xp下asp.net应用使用的账户是netword service,所以没法建立oracle链接,只要重设一下ORACLE_HOME目录的权限就能够了。
解决办法:
一、以管理员的用户登陆;
二、找到ORACLE_HOME文件夹(个人是d:/oracle/ora92),点右键,选属性--安全,在组或用户栏中选“Authenticated Users”,在下面权限列表中把“读取和运行”的权限去掉,再按应用;从新选上“读取和运行”权限,点击应用;选权限框下面的“高级”按钮,确认“Authenticated Users”后面的应用因而“该文件夹、子文件夹及文件”,按肯定把权限的更改应用于该文件夹;
三、从新启动计算机,让权限设置生效(请注意,这一步很重要);
四、登陆后运行asp.net应用,正常取得Oracle数据库的数据。
应用Authenticated Users的权限时间可能很长,由于ora92目录中的文件数量不少。
注意:上面这些是设置权限方面的,若是配置完上面这些报ORA-12154的错误,须要在服务器上配置“Net Configuration Assistant”。数据库