gpt4 book ai didi

.net - Oracle.DataAccess.Client 错误

转载 作者:行者123 更新时间:2023-12-02 17:44:44 41 4
gpt4 key购买 nike

背景:本网站使用 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=*****)))" />

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

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

oci
ociw32
Oracle.DataAccess
oranzsbb11
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 有关系吗?谢谢

最佳答案

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

首先,此错误消息与 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(否则它会抛出“The provider is not compatible with the version of oracle client”错误)和相关的 oracle instant client相同的位置(否则它会抛出“无法加载文件或程序集‘Oracle.DataAccess’或其依赖项之一。尝试加载格式不正确的程序。”错误)。 p>

如果您使用 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。

关于.net - Oracle.DataAccess.Client 错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16545842/

41 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com