問題描述
我正在使用 .Net 庫的 System.DirectoryServices.AccountManagement 部分來連接到 ActiveDirectory.
I am using the System.DirectoryServices.AccountManagement part of the .Net library to interface into ActiveDirectory.
在 GroupPrincipal 對象上調用 GetMembers() 并過濾結果后,我現在有一組 UserPrincipal 對象
Having called GetMembers() on a GroupPrincipal object and filter the results, I now have a collection of UserPrincipal objects
GroupPrincipal myGroup; // population of this object omitted here
foreach (UserPrincipal user in myGroup.GetMembers(false).OfType<UserPrincipal>())
{
Console.WriteLine(user.SamAccountName);
}
上面的代碼示例將打印出像TestUser1"這樣的用戶名.我需要將這些與來自DOMAINTestUser1"格式的另一個應用程序的列表進行比較.
The above code sample will print out usernames like "TestUser1". I need to compare these to a list coming from another application in "DOMAINTestUser1" format.
如何從 UserPrincipal 對象中獲取DOMAIN"部分?
How do I get the "DOMAIN" part from the UserPrincipal object?
我不能只附加一個已知域名,因為涉及多個域,我需要區分 DOMAIN1TestUser1 和 DOMAIN2TestUser2.
I can't just append a known domain name as there are multiple domains involved and I need to differentiate DOMAIN1TestUser1 and DOMAIN2TestUser2.
推薦答案
你有兩個我能想到的選擇.
You have two choices that I can think of.
- 解析或獲取
name@fully.qualified.domain.name
右側的所有內容; - 使用
System.DirectoryServices
命名空間.
- Parse, or take everything that is on, the right of
name@fully.qualified.domain.name
; - Use the
System.DirectoryServices
namespace.
我不了解 UserPrincipal,也不了解 GroupPrincipal.另一方面,我知道一種可行的方法來實現你想要的.
I don't know about UserPrincipal, neither do I about GroupPrincipal. On the other hand, I know of a working way to achive to what you want.
[TestCase("LDAP://fully.qualified.domain.name", "TestUser1")]
public void GetNetBiosName(string ldapUrl, string login)
string netBiosName = null;
string foundLogin = null;
using (DirectoryEntry root = new DirectoryEntry(ldapUrl))
Using (DirectorySearcher searcher = new DirectorySearcher(root) {
searcher.SearchScope = SearchScope.Subtree;
searcher.PropertiesToLoad.Add("sAMAccountName");
searcher.Filter = string.Format("(&(objectClass=user)(sAMAccountName={0}))", login);
SearchResult result = null;
try {
result = searcher.FindOne();
if (result == null)
if (string.Equals(login, result.GetDirectoryEntry().Properties("sAMAccountName").Value))
foundLogin = result.GetDirectoryEntry().Properties("sAMAccountName").Value
} finally {
searcher.Dispose();
root.Dispose();
if (result != null) result = null;
}
}
if (!string.IsNullOrEmpty(foundLogin))
using (DirectoryEntry root = new DirectoryEntry(ldapUrl.Insert(7, "CN=Partitions,CN=Configuration,DC=").Replace(".", ",DC="))
Using DirectorySearcher searcher = new DirectorySearcher(root)
searcher.Filter = "nETBIOSName=*";
searcher.PropertiesToLoad.Add("cn");
SearchResultCollection results = null;
try {
results = searcher.FindAll();
if (results != null && results.Count > 0 && results[0] != null) {
ResultPropertyValueCollection values = results[0].Properties("cn");
netBiosName = rpvc[0].ToString();
} finally {
searcher.Dispose();
root.Dispose();
if (results != null) {
results.Dispose();
results = null;
}
}
}
Assert.AreEqual("INTRATESTUSER1", string.Concat(netBiosName, "", foundLogin).ToUpperInvariant())
}
此 SO 問題中提供的其他相關信息或鏈接.
C# Active Directory:獲取用戶的域名?>
如何查找域的 NetBIOS 名稱
Other related information or links available in this SO question.
C# Active Directory: Get domain name of user?
How to find the NetBIOS name of a domain
這篇關于從 UserPrincipal 對象中獲取 nETBIOSName的文章就介紹到這了,希望我們推薦的答案對大家有所幫助,也希望大家多多支持html5模板網!