c# - 如何在 C# 中获取当前用户的 Active Directory 详细信息

标签 c# .net active-directory ldap windows-authentication

我正在开发一个使用 Windows 身份验证的 C# 和 ASP.Net 应用程序。

即在 Web.config 中:

<system.web>
    <authentication mode="Windows" />
</system.web>

我想从 Active Directory 获取当前用户的详细信息(全名、电子邮件地址等)。


我可以使用

获取他们的 Windows 2000 之前的用户登录名(例如:SOMEDOMAIN\someuser)
string username = HttpContext.Current.Request.ServerVariables["AUTH_USER"];

我已经为用户制定了 LDAP 查询,使用他们当前的登录名(不是他们的 Windows 2000 之前的用户登录名):

DirectorySearcher adSearch = new DirectorySearcher(
        "(userprincipalname=someuser@somedomain.com.au)");
SearchResult adSearchResult = adSearch.FindOne();

但是,我不知道如何使用 W2K 之前的登录名搜索用户的 AD,或者以“someuser@somedomain.com.au”格式获取他们的登录名。

有什么想法吗?

最佳答案

“pre Windows 2000”名称即 DOMAIN\SomeBodySomebody 部分称为 sAMAccountName。

所以尝试:

using(DirectoryEntry de = new DirectoryEntry("LDAP://MyDomainController"))
{
   using(DirectorySearcher adSearch = new DirectorySearcher(de))
   {
     adSearch.Filter = "(sAMAccountName=someuser)";
     SearchResult adSearchResult = adSearch.FindOne();
   }
}

someuser@somedomain.com.au 是 UserPrincipalName,但它不是必填字段。

关于c# - 如何在 C# 中获取当前用户的 Active Directory 详细信息,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/637486/

相关文章:

c# - 有关美国税收的特定编程问题(示例 : Zip+4 or City/State/etc. )

c# - 发送电子邮件到雅虎帐户

c# - 一致地生成对象的哈希值

c# - .NET 核心 - 依赖注入(inject)、工厂和 IDisposable

vb.net - 在 VB.NET 中查询 LDAP。我有用户帐户,我想要一个用户所在组的列表

c#-4.0 - C# LDAP SetPassword 抛出 RPC 服务器不可用

c# - 设置二进制值时属性异常

c# - 使用 sdf 文件的 Linq to SQL 异常

c# - 当逆变导致歧义时,没有警告或错误(或运行时失败)

Azure辅助角色模拟域帐户