跨多个 Active Directory 域搜索用户

Searching for users across multiple Active Directory domains(跨多个 Active Directory 域搜索用户)
本文介绍了跨多个 Active Directory 域搜索用户的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

问题描述

我正在使用 System.DirectoryServices.AccountManagement 来提供用户查找功能.

I'm using the System.DirectoryServices.AccountManagement to provide user lookup functionality.

该企业有多个特定于区域的 AD 域:AMR、EUR、JPN 等.

The business has several region specific AD domains: AMR, EUR, JPN etc.

以下内容适用于 EUR 域,但不会返回来自其他域的用户(自然):

The following works for the EUR domain, but doesn't return users from the other domains (naturally):

var context = new PrincipalContext(ContextType.Domain, "mycorp.com", "DC=eur,DC=mycorp,DC=com");

var query = new UserPrincipal(GetContext());

query.Name = "*Bloggs*";

var users = new PrincipalSearcher(query).FindAll().ToList();

但是,如果我定位整个目录,它不会返回来自任何区域特定域的用户:

However, if I target the entire directory, it doesn't return users from any of the region specific domains:

var context = new PrincipalContext(ContextType.Domain, "mycorp.com", "DC=mycorp,DC=com");

如何搜索整个目录?

更新

阅读Active Directory 搜索的工作原理":

Read up on "How Active Directory Searches Work":

http://technet.microsoft.com/en-us/library/cc755809(v=ws.10).aspx

如果我在服务器名称后缀 3268 端口,它会针对全局目录进行搜索:

If I suffix the server name with port 3268 it searches against the Global Catalog:

var context = new PrincipalContext(ContextType.Domain, "mycorp.com:3268", "DC=mycorp,DC=com");

但是它非常非常慢.关于如何提高性能有什么建议吗?

However it's very, very slow. Any suggestions on how to improve performance?

推荐答案

具有初始通配符 (*Bloggs*) 的查询会很慢,除非您在要查询的属性上有元组索引.AD 中的所有属性都没有默认设置.最好不要做初始通配符.

Queries which have initial wildcards (*Bloggs*) will be slow unless you have a tuple index on the attribute being queries. None of the attributes in AD have this set by default. Better to not do initial wildcards.

这篇关于跨多个 Active Directory 域搜索用户的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

Finding Active Directory users from 2 OU(从 2 个 OU 中查找 Active Directory 用户)
How to set a binary attribute when using a AccountManagement Extension Class?(使用 AccountManagement 扩展类时如何设置二进制属性?)
Getting last Logon Time on Computers in Active Directory(在 Active Directory 中的计算机上获取上次登录时间)
Active Directory - Roles of a user(Active Directory - 用户的角色)
How to connect to Active Directory via LDAPS in C#?(如何在 C# 中通过 LDAPS 连接到 Active Directory?)
Why is DirectorySearcher so slow when compared to PrincipalSearcher?(与 PrincipalSearcher 相比,为什么 DirectorySearcher 如此缓慢?)