这是老问题,但我刚刚遇到它并想分享更多细节。
首先,如果您需要执行以下操作,这是最简单的解决方案<clear/>
在你的connectionStrings块中,将一个空白的OraAspNetConString连接字符串条目添加回你的web.config中:
<connectionStrings>
<clear />
<add name="OraAspNetConString" connectionString=" "/>
</connectionStrings>
当你时会发生什么安装 Oracle .NET 包 http://docs.oracle.com/cd/B28359_01/win.111/e10928/IntroInstallation.htm在您的任何机器上,它都会将大量不同的提供程序与 OraAspNetConString 作为机器级连接字符串一起安装到您的 machine.config 中。这<clear/>
element 摆脱了 OraAspNetConString,并且由于 Oracle 的 machine.config 添加,默认加载的所有其他 Oracle 提供程序在找不到连接字符串时都会崩溃。
您探索使用成员资格提供程序元素的另一个答案不起作用,因为在 machine.config 中添加的大多数其他 Oracle 提供程序仍然会寻找该提供程序OraAspNetConString因此,仅清除一个提供商无法帮助您。
这些是他们安装到我的 machine.config 中的所有提供程序:
<membership><providers>
<add name="OracleMembershipProvider" type="Oracle.Web.Security.OracleMembershipProvider, Oracle.Web, Version=4.112.2.0, Culture=neutral, PublicKeyToken=89b483f429c47342" connectionStringName="OraAspNetConString" applicationName="" />
</providers></membership>
<profile><providers>
<add name="OracleProfileProvider" type="Oracle.Web.Profile.OracleProfileProvider, Oracle.Web, Version=4.112.2.0, Culture=neutral, PublicKeyToken=89b483f429c47342" connectionStringName="OraAspNetConString" applicationName=""/>
</providers></profile>
<roleManager><providers>
<add name="OracleRoleProvider" type="Oracle.Web.Security.OracleRoleProvider, Oracle.Web, Version=4.112.2.0, Culture=neutral, PublicKeyToken=89b483f429c47342" connectionStringName="OraAspNetConString" applicationName=""/>
</providers></roleManager>
<siteMap><providers>
<add name="OracleSiteMapProvider" type="Oracle.Web.SiteMap.OracleSiteMapProvider, Oracle.Web, Version=4.112.2.0, Culture=neutral, PublicKeyToken=89b483f429c47342" connectionStringName="OraAspNetConString" applicationName="" securityTrimmingEnabled="true"/>
</providers></siteMap>
<webParts>
<personalization>
<providers>
<add name="OraclePersonalizationProvider" type="Oracle.Web.Personalization.OraclePersonalizationProvider, Oracle.Web, Version=4.112.2.0, Culture=neutral, PublicKeyToken=89b483f429c47342" connectionStringName="OraAspNetConString" applicationName=""/>
</providers>
</personalization>
</webParts>
<healthMonitoring><providers>
<add name="OracleWebEventProvider" type="Oracle.Web.Management.OracleWebEventProvider, Oracle.Web, Version=4.112.2.0, Culture=neutral, PublicKeyToken=89b483f429c47342" connectionStringName="OraAspNetConString" buffer="true" bufferMode="OracleNotification"/>
</providers></healthMonitoring>
因此,如果您不想添加空白 OraAspNetConString,则必须确保您要么<clear/>
以下每一个 Oracle 提供程序或进入并添加一个<remove name=x />
每个提供者类的元素如下:
<membership><providers>
<remove name="OracleMembershipProvider" />
</providers></membership>
<profile><providers>
<remove name="OracleProfileProvider" />
</providers></profile>
<roleManager><providers>
<remove name="OracleRoleProvider" />
</providers></roleManager>
<siteMap><providers>
<remove name="OracleSiteMapProvider" />
</providers></siteMap>
<healthMonitoring><providers>
<remove name="OracleWebEventProvider" />
</providers></healthMonitoring>
我从未在我的网络应用程序中处理过任何 siteMap 或运行状况监控代码,但我仍然必须手动添加这些<remove/>
我的 web.config 中不同提供程序的元素或者某些东西在寻找不存在的 OraAspNetConString 连接字符串时会崩溃。