是否可以使用 asp.net 的网页风格对具有 Active Directory 成员资格的用户进行身份验证?从我在网上看到的大多数示例中,我注意到网页使用简单的会员提供程序。
2 回答
我过去曾成功使用此设置在 .net 网页上使用 Active Directory 进行身份验证:http: //msdn.microsoft.com/en-us/library/ff650308.aspx
更新:
上一个链接适用于“Web 表单”/framework 2.0。这似乎相当于“网页”: http: //www.mikesdotnetting.com/Article/216/Windows-Authentication-With-ASP.NET-Web-Pages
我从未使用过为网页描述的方法,但查看代码并进行比较,它似乎在做同样的事情,即禁用默认的 SimpleMembership 身份验证并改用 AD。希望这可以帮助。
如果您尝试在带有表单身份验证的 asp.net 应用程序中使用自定义登录页面,则可以非常轻松地使用 AD。在 Web.config 中的表单身份验证下,放置下面列出的成员资格提供程序。然后在您的 connectionStrings 中,将 AD 服务连接与您的信息放在下面。之后,由于您将拥有更多页面,因此您要确保它们不能只是简单地导航到这些页面。通过使用 . 然后,任何拥有 Active Directory 帐户的人都可以访问该站点。建议使用角色来拒绝用户访问网站的某些部分。您还可以将身份验证模式从“表单”更改为“Windows”,这使用 AD 登录。我需要它更安全一些,因为我公司的一些人不需要看到这个网站。为此,我根据 SQL 数据库验证用户名。只要用户名与数据库中的用户名匹配,就可以登录。希望对您有所帮助!
<membership defaultProvider="AspNetActiveDirectoryMembershipProvider">
<providers>
<clear />
<!--Membership provider for Active Directory-->
<add name="AspNetActiveDirectoryMembershipProvider" type="System.Web.Security.ActiveDirectoryMembershipProvider, System.Web, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a" connectionStringName="ADService" attributeMapUsername="sAMAccountName"/>
</providers>
</membership>
<connectionStrings>
<add name="ADService" connectionString="LDAP://YOURDOMAINNAME/OU=YOURORGANIZATIONALGROUP,DC=YOURDOMAINCONTROLLER,DC=net" />
</connectionStrings>
//This deny's all users who do not have an AD account.
<location path="Default.aspx">
<system.web>
<authorization>
<deny users="?" />
</authorization>
</system.web>
</location>