2

背景:本网站使用oracle和spring.net。
Oracle.DataAccess 版本:4.112.2.0
Spring 版本:1.3.2.40943

网络配置文件

<db:provider id="SDDbProvider" provider="Oracle.DataAccess.Client"
           connectionString="User Id=****; Password = *****; Data Source = (DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=****)(PORT=****))(CONNECT_DATA=(SERVER=dedicated)(SERVICE_NAME=*****)))" />

这在调试模式下工作正常。我在本地 IIS (7.5) 上发布了这个网站,它也运行良好。但是当我将发布的文件夹复制到远程服务器(也运行 IIS 7.5)时,它会出现以下错误。

注意:我检查了已发布文件夹中的 bin,它具有 Oracle 所需的所有 DLL

oci
ociw32
Oracle.DataAccess
orannzsbb11
oraocci11
oraociei11
OraOps11w

Error thrown by a dependency of object 'Oracle.DataAccess.Client' defined in 'assembly [Spring.Data, Version=1.3.2.40943, Culture=neutral, PublicKeyToken=65e474d141e25e07], resource [Spring.Data.Common.dbproviders.xml] line 400' : Unsatisfied dependency expressed through constructor argument with index 2 of type [System.Type] : Could not convert constructor argument value [Oracle.DataAccess.Client.OracleConnection, Oracle.DataAccess, Version=2.102.2.20, Culture=neutral, PublicKeyToken=89b483f429c47342] to required type [System.Type] : Cannot convert property value of type [System.String] to required type [System.Type] for property ''.
while resolving 'constructor argument with name dbmetadata' to 'Spring.Data.Common.DbMetadata#195EA5D' defined in 'assembly [Spring.Data, Version=1.3.2.40943, Culture=neutral, PublicKeyToken=65e474d141e25e07], resource [Spring.Data.Common.dbproviders.xml] line 400' 


[UnsatisfiedDependencyException: Error thrown by a dependency of object 'Oracle.DataAccess.Client' defined in 'assembly [Spring.Data, Version=1.3.2.40943, Culture=neutral, PublicKeyToken=65e474d141e25e07], resource [Spring.Data.Common.dbproviders.xml] line 400' : Unsatisfied dependency expressed through constructor argument with index 2 of type [System.Type] : Could not convert constructor argument value [Oracle.DataAccess.Client.OracleConnection, Oracle.DataAccess, Version=2.102.2.20, Culture=neutral, PublicKeyToken=89b483f429c47342] to required type [System.Type] : Cannot convert property value of type [System.String] to required type [System.Type] for property ''.
 while resolving 'constructor argument with name dbmetadata' to 'Spring.Data.Common.DbMetadata#25C456C' defined in 'assembly [Spring.Data, Version=1.3.2.40943, Culture=neutral, PublicKeyToken=65e474d141e25e07], resource [Spring.Data.Common.dbproviders.xml] line 400']
   Spring.Objects.Factory.Support.ObjectDefinitionValueResolver.ResolveInnerObjectDefinition(String name, String innerObjectName, String argumentName, IObjectDefinition definition, Boolean singletonOwner) +385
   Spring.Objects.Factory.Support.ObjectDefinitionValueResolver.ResolvePropertyValue(String name, IObjectDefinition definition, String argumentName, Object argumentValue) +278
   Spring.Objects.Factory.Support.ObjectDefinitionValueResolver.ResolveValueIfNecessary(String name, IObjectDefinition definition, String argumentName, Object argumentValue) +19
   Spring.Objects.Factory.Support.ConstructorResolver.ResolveConstructorArguments(String objectName, RootObjectDefinition definition, ObjectWrapper wrapper, ConstructorArgumentValues cargs, ConstructorArgumentValues resolvedValues) +1385
   Spring.Objects.Factory.Support.ConstructorResolver.GetConstructorInstantiationInfo(String objectName, RootObjectDefinition rod, ConstructorInfo[] chosenCtors, Object[] explicitArgs) +218
   Spring.Objects.Factory.Support.ConstructorResolver.AutowireConstructor(String objectName, RootObjectDefinition rod, ConstructorInfo[] chosenCtors, Object[] explicitArgs) +79
   Spring.Objects.Factory.Support.AbstractAutowireCapableObjectFactory.CreateObjectInstance(String objectName, RootObjectDefinition objectDefinition, Object[] arguments) +278
   Spring.Objects.Factory.Support.AbstractAutowireCapableObjectFactory.InstantiateObject(String name, RootObjectDefinition definition, Object[] arguments, Boolean allowEagerCaching, Boolean suppressConfigure) +1204
   Spring.Objects.Factory.Support.AbstractObjectFactory.GetObjectInternal(String name, Type requiredType, Object[] arguments, Boolean suppressConfigure) +2216
   Spring.Objects.Factory.Support.AbstractObjectFactory.GetObject(String name, Type requiredType) +21
   Spring.Data.Common.DbProviderFactory.GetDbProvider(String providerInvariantName) +81
   Spring.Data.Common.DbProviderFactoryObject.CreateProviderInstance() +18
   Spring.Data.Common.DbProviderFactoryObject.GetObject() +205
   Spring.Objects.Factory.Support.AbstractObjectFactory.GetObjectFromFactoryObject(IFactoryObject factory, String objectName, RootObjectDefinition rod) +98

[ObjectCreationException: Error creating object with name 'SDDbProvider' : FactoryObject threw exception on object creation.]
   System.Web.HttpApplication.RegisterEventSubscriptionsWithIIS(IntPtr appContext, HttpContext context, MethodInfo[] handlers) +4649821
   System.Web.HttpApplication.InitSpecial(HttpApplicationState state, MethodInfo[] handlers, IntPtr appContext, HttpContext context) +325
   System.Web.HttpApplicationFactory.GetSpecialApplicationInstance(IntPtr appContext, HttpContext context) +407
   System.Web.Hosting.PipelineRuntime.InitializeApplication(IntPtr appContext) +375

[HttpException (0x80004005): Error creating object with name 'SDDbProvider' : FactoryObject threw exception on object creation.]
   System.Web.HttpRuntime.FirstRequestInit(HttpContext context) +11529072
   System.Web.HttpRuntime.EnsureFirstRequestInit(HttpContext context) +141
   System.Web.HttpRuntime.ProcessRequestNotificationPrivate(IIS7WorkerRequest wr, HttpContext context) +4784373

知道为什么会这样吗?它与远程服务器中的 GAC 有关吗?谢谢

4

4 回答 4

5

我猜一周后我解决了这个问题。想分享一下我的经验。

首先,此错误消息与 Spring 框架有关。基于我们在配置文件中指定的 DBprovider(在我的例子中是Oracle.DataAccess.Client),Spring.Data DLL 尝试解析数据库提供程序。(有关 Spring dbproviders 的更多信息

它使用资源文件 (Spring.Data.Common.dbproviders.xml) 来解决这个问题。dbproviders.xml 文件中的以下行引发错误。(文件位置:Spring.Net/src/Spring/Spring.Data/Data/Common/dbproviders.xml)

 <constructor-arg name="connectionType" value="Oracle.DataAccess.Client.OracleConnection, Oracle.DataAccess, Version=2.102.2.20, Culture=neutral, PublicKeyToken=89b483f429c47342"/>

出于某种原因,dbproviders.xml 尝试在 GAC (windows/assembly/GAC) 中查找 Oracle.DataAccess DLL。根据我的经验,它不在bin 文件夹中。如果在 GAC 中找不到 DLL,则会抛出上述错误消息。所以我使用 GACUtil 在 GAC 中安装了 Oracle.DataAccess(版本 2.102.4.0)DLL。我认为它看起来也是 dbproviders.xml 中指定的版本。(如果我错了,请随时在这里评论)

这是针对 Spring 框架的。但是,为了工作 NHibernate,您应该在 BIN 文件夹中有 Oracle.DataAccess DLL(否则它会抛出“ The provider is not compatible with the version of oracle client ”错误)和相关的 oracle 即时客户端在同一位置(否则它会抛出“无法加载文件或程序集“Oracle.DataAccess”或其依赖项之一。试图加载格式不正确的程序。”错误)。

如果您使用 oracle 即时客户端,则不必在机器上安装 oracle 客户端(很确定每个人都知道)。在我的 bin 文件夹中,我放置了 Oracle.DataAccess(版本 4.112.2.0)和即时客户端 DLL(如问题中所述)。我使用了 4.112.2.0版本,因为我找不到 2.102.4.0 版本的即时客户端 DLL。(我知道这是一团糟,但这就是它的工作原理)

所以现在一切正常。

小提示:如果有人想在远程服务器中使用 GacUtil 并且不想安装 .net 框架 SDK,请将 gacutil.exe 和 gacutil.exe.config 文件复制到远程服务器并在那里运行。确保使用 version="v2.0.50727"。如果您使用 version="v4.0.30319",那么它会将 DLL 添加到 C:\Windows\Microsoft.NET\assembly 而不是 C:\Windows\assembly。

于 2013-05-22T09:25:44.420 回答
1

确保您在 64 位处理器上编译。很多环境默认为 32 位,无法识别 64 位 dll。

于 2015-01-16T18:24:08.350 回答
0

Oracle windows 客户端是最差的。你有我的同情。

通过检查 GAC,您走在了正确的轨道上。特别要密切注意任何 Oracle.DataAccess.Policy 条目。这些允许 Oracle 假设版本之间的向后兼容性。在同一台机器上安装多个版本的 Oracle 客户端时,Oracle 安装程序可能会对应该使用哪个版本做出一些错误的假设。如果可能的话,我建议只安装 1 个版本的 Oracle,或者在 GAC 中至少配置 1 个版本。

检查此线程以获得调试问题的帮助: https ://forums.oracle.com/forums/thread.jspa?threadID=415012

于 2013-05-14T15:08:15.127 回答
0

我有一个类似的问题,修复是为项目中包含的版本添加一个程序集绑定重定向到 web.config。我注意到这是必需的,因为我在服务器上启用了 fusionlog(如何在 .NET 中启用程序集绑定失败日志记录(Fusion)

顺便说一句,Microsoft 不建议将 GacUtil 用于生产服务器。

于 2019-07-09T11:40:30.553 回答