你的位置:首页 > 数据库

[数据库]WebServers发布提示oracle客户端模式不一致


问题:System.InvalidOperationException: 尝试加载 Oracle 客户端库时引发BadImageFormatException。如果在安装32 位Oracle 客户端组件的情况下以64 位模式运行,将出现此问题。---> System.BadImageFormatException: 试图加载格式不正确的程序。 (异常来自HRESULT:0x8007000B)

分析:提示很明显在64 bits的环境下使用了32位的oracle客户端组件。但是我们检查oracle是安装的64bits的服务端程序,并没有安装32的任何组件。(IIS程序池以32位模式运行)

检查IIS配置,发现Application Pool被设置成了运行32位模式。那么这样会导致程序使用32位的Oracle客户端运行在这32位的应用程序池。 

因为IIS启动该应用程序池的工作进程,是一个32位的过程中,当它试图加载CLR,它会加载的32位CLR,因此将在32位模式下加载程序集。这即使您的程序集编译为64位和32位模式。在32位模式下运行您的程序集,然后可以调用Oracle客户端,将在32位模式下运行。

解决:设置application pool的配置Application Pools -> Advanced Settings -> Enable 32-Bit Applications为true。