Oracle.DataAccess.Client错误

时间:2013-05-14 14:26:27

标签: .net oracle spring spring.net

背景: 这个网站使用oracle和spring.net。
Oracle.DataAccess的版本:4.112.2.0
春天的版本:1.3.2.40943

Webconfig文件

<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)&amp;这也很好。 但是,当我将发布的文件夹复制到远程服务器(也运行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 个答案:

答案 0 :(得分:5)

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

首先,此错误消息与Spring框架有关。基于我们在配置文件中指定的DBprovider(在我的情况下,它是 Oracle.DataAccess.Client ),Spring.Data DLL尝试解析数据库提供程序。 (More about 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(否则它会抛出“提供者与oracle客户端的版本不兼容”错误)和相关的oracle即时客户端相同的位置(否则它会抛出“无法加载文件或程序集'Oracle.DataAccess'或其中一个依赖项。尝试加载格式不正确的程序。”错误)。

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

所以现在一切正常。

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

答案 1 :(得分:1)

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

答案 2 :(得分:0)

Oracle Windows客户端是最糟糕的。你有我的同情心。

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

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

答案 3 :(得分:0)

我遇到了类似的问题,此修复程序是将项目中包含的版本的程序集绑定重定向添加到web.config。我注意到这是必需的,因为我在服务器(How to enable assembly bind failure logging (Fusion) in .NET)上启用了Fusionlog

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