我得到了以下错误:
无法加载文件或程序集“System.Web”或其依赖项之一。系统找不到指定的文件。
我试图在Web.Config中进行LDAP成员资格配置,并在前面提出了这个问题,但我认为这可能是一个更普遍的问题。我正在使用‘m 2010/.NET 4.0中的Visual开发服务器
编辑: Web.Config如下所示
<?xml version="1.0" encoding="utf-8"?>
<!--
For more information on how to configure your ASP.NET application, please visit
http://go.microsoft.com/fwlink/?LinkId=169433
-->
<configuration>
<configSections>
<!-- For more information on Entity Framework configuration, visit http://go.microsoft.com/fwlink/?LinkID=237468 -->
<section name="entityFramework" type="System.Data.Entity.Internal.ConfigFile.EntityFrameworkSection, EntityFramework, Version=4.4.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" requirePermission="false" />
<sectionGroup name="applicationSettings" type="System.Configuration.ApplicationSettingsGroup, System, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" >
<section name="FPLMobileWebApp.Properties.Settings" type="System.Configuration.ClientSettingsSection, System, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" requirePermission="false" />
</sectionGroup>
</configSections>
<connectionStrings>
<add name="LDAPConnectionString" connectionString="LDAP://ad.company.com/CN=Users,DC=company,DC=com" />
</connectionStrings>
<appSettings>
<add key="aspnet:UseTaskFriendlySynchronizationContext" value="true" />
<add key="webpages:Version" value="2.0.0.0" />
<add key="webpages:Enabled" value="false" />
<add key="PreserveLoginUrl" value="true" />
<add key="ClientValidationEnabled" value="true" />
<add key="UnobtrusiveJavaScriptEnabled" value="true" />
</appSettings>
<system.web>
<compilation debug="true" targetFramework="4.0" />
<authentication mode="Forms">
<forms name=".ADAuthCookie" loginUrl="~/Account/Login" timeout="2880" defaultUrl="~/FPL/Search" />
</authentication>
<pages>
<namespaces>
<add namespace="System.Web.Helpers" />
<add namespace="System.Web.Mvc" />
<add namespace="System.Web.Mvc.Ajax" />
<add namespace="System.Web.Mvc.Html" />
<add namespace="System.Web.Optimization" />
<add namespace="System.Web.Routing" />
<add namespace="System.Web.WebPages" />
</namespaces>
</pages>
<profile defaultProvider="DefaultProfileProvider">
<providers>
<add name="DefaultProfileProvider" type="System.Web.Providers.DefaultProfileProvider, System.Web.Providers, Version=1.0.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35" connectionStringName="DefaultConnection" applicationName="/" />
</providers>
</profile>
<membership defaultProvider="DomainLoginMembershipProvider">
<providers>
<clear/>
<add name="DomainLoginMembershipProvider" type="System.Web.Security.ActiveDirectoryMembershipProvider, System.Web" connectionStringName="LDAPConnectionString" attributeMapUsername="sAMAccountName" applicationName="/" />
</providers>
</membership>
<roleManager defaultProvider="DefaultRoleProvider">
<providers>
<add name="DefaultRoleProvider" type="System.Web.Providers.DefaultRoleProvider, System.Web.Providers, Version=1.0.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35" connectionStringName="DefaultConnection" applicationName="/" />
</providers>
</roleManager>
<sessionState mode="InProc" customProvider="DefaultSessionProvider">
<providers>
<add name="DefaultSessionProvider" type="System.Web.Providers.DefaultSessionStateProvider, System.Web.Providers, Version=1.0.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35" />
</providers>
</sessionState>
</system.web>
<system.webServer>
<validation validateIntegratedModeConfiguration="false" />
<modules runAllManagedModulesForAllRequests="true" />
</system.webServer>
<runtime>
<assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1">
<dependentAssembly>
<assemblyIdentity name="System.Web.Helpers" publicKeyToken="31bf3856ad364e35" />
<bindingRedirect oldVersion="1.0.0.0-2.0.0.0" newVersion="2.0.0.0" />
</dependentAssembly>
<dependentAssembly>
<assemblyIdentity name="System.Web.Mvc" publicKeyToken="31bf3856ad364e35" />
<bindingRedirect oldVersion="1.0.0.0-4.0.0.0" newVersion="4.0.0.0" />
</dependentAssembly>
<dependentAssembly>
<assemblyIdentity name="System.Web.WebPages" publicKeyToken="31bf3856ad364e35" />
<bindingRedirect oldVersion="1.0.0.0-2.0.0.0" newVersion="2.0.0.0" />
</dependentAssembly>
</assemblyBinding>
</runtime>
<entityFramework>
<defaultConnectionFactory type="System.Data.Entity.Infrastructure.SqlConnectionFactory, EntityFramework" />
</entityFramework>
<applicationSettings>
<FPLMobileWebApp.Properties.Settings>
<setting name="FPLMobileWebApp_FPLdb_Parts" serializeAs="String">
<value>http://a09devlab/pld/parts.asmx</value>
</setting>
</FPLMobileWebApp.Properties.Settings>
</applicationSettings>
</configuration>编辑:我只是将System.Web dll添加到我的应用程序的bin文件夹。但是,我想确保这是正确的部署,现在它是说我的连接字符串不存在。
发布于 2012-07-16 13:52:35
,我认为这是一个权限问题。
看看MSDN。
ActiveDirectoryMembershipProvider实例仅在完全信任策略默认配置ASP.NET中工作。为了在任何部分信任级别上使用ActiveDirectoryMembershipProvider实例,要么必须更改应用程序的适当信任策略文件,要么必须创建部署在GAC中的“沙箱”程序集。 ActiveDirectoryMembershipProvider类需要无限制的DirectoryServicesPermission权限才能运行。此权限不会添加到ASP.NET提供的任何部分信任策略文件中,虽然将DirectoryServicesPermission权限添加到部分信任策略文件中将允许使用ActiveDirectoryMembershipProvider类,但这样做可以使System.DirectoryServices命名空间类对运行在ASP.NET页面中的任何代码可用。对于任何需要在安全锁定模式下运行的Web服务器,不建议使用此选项。 作为另一种选择,您可以创建一个“沙箱”程序集,该程序集调用ActiveDirectoryMembershipProvider类。此程序集可以包含将方法调用转发给ActiveDirectoryMembershipProvider类的包装类,也可以包含从ActiveDirectoryMembershipProvider类派生的类。在任何一种情况下,包装类都必须断言不受限制的DirectoryServicesPermission权限。在GAC中部署沙箱程序集,并使用AllowPartiallyTrustedCallersAttribute (APTCA)属性标记程序集。这将使部分受信任的ASP.NET代码能够调用包装类,而且由于包装类在内部断言无限制的DirectoryServicesPermission权限,所以包装类将能够成功地调用提供程序。
因此,解决该问题的最简单方法(如果您确实面临安全问题)是将完全信任策略设置为您的应用程序。
该怎么做呢?看看Technet
https://stackoverflow.com/questions/11505755
复制相似问题