C# 获取用户';来自Active Directory的s管理器详细信息
如何从与用户关联的active directory管理器获取管理器名称和电子邮件地址等详细信息 我能够获得用户的所有详细信息:C# 获取用户';来自Active Directory的s管理器详细信息,c#,active-directory,C#,Active Directory,如何从与用户关联的active directory管理器获取管理器名称和电子邮件地址等详细信息 我能够获得用户的所有详细信息: ActiveDirectory.SearchUserinAD("ads", "sgupt257"); public static bool SearchUserinAD(string domain, string username) { using (var domainContext = new PrincipalConte
ActiveDirectory.SearchUserinAD("ads", "sgupt257");
public static bool SearchUserinAD(string domain, string username)
{
using (var domainContext = new PrincipalContext(ContextType.Domain, domain))
{
using (var user = new UserPrincipal(domainContext))
{
user.SamAccountName = username;
using (var pS = new PrincipalSearcher())
{
pS.QueryFilter = user;
var results = pS.FindAll().Cast<UserPrincipal>();
{
foreach (var item in results)
{
File.WriteAllText("F:\\webapps\\CIS\\UserInfo.txt", item.DisplayName + item.Name + item.EmailAddress + item.EmployeeId + item.VoiceTelephoneNumber + item.Guid + item.Context.UserName + item.Sid);
}
if (results != null && results.Count() > 0)
{
return true;
}
}
}
}
}
return false;
}
ActiveDirectory.SearchUserinAD(“ads”、“sgupt257”);
公共静态bool SearchUserinAD(字符串域,字符串用户名)
{
使用(var domainContext=newprincipalcontext(ContextType.Domain,Domain))
{
使用(var user=newuserprincipal(domainContext))
{
user.SamAccountName=用户名;
使用(var pS=new PrincipalSearcher())
{
pS.QueryFilter=用户;
var results=pS.FindAll().Cast();
{
foreach(结果中的var项目)
{
File.writealText(“F:\\webapps\\CIS\\UserInfo.txt”,item.DisplayName+item.Name+item.EmailAddress+item.EmployeeId+item.VoiceTelephoneNumber+item.Guid+item.Context.UserName+item.Sid);
}
if(results!=null&&results.Count()>0)
{
返回true;
}
}
}
}
}
返回false;
}
谢谢。我使用DirectorySearcher从广告中获取数据。 您可以通过以下方式获得manager:
DirectoryEntry dirEntry = new DirectoryEntry("LDAP://DC=company,DC=com");
DirectorySearcher search = new DirectorySearcher(dirEntry);
search.PropertiesToLoad.Add("cn");
search.PropertiesToLoad.Add("displayName");
search.PropertiesToLoad.Add("manager");
search.PropertiesToLoad.Add("mail");
search.PropertiesToLoad.Add("sAMAccountName");
if (username.IndexOf('@') > -1)
{
// userprincipal username
search.Filter = "(userPrincipalName=" + username + ")";
}
else
{
// samaccountname username
String samaccount = username;
if (username.IndexOf(@"\") > -1)
{
samaccount = username.Substring(username.IndexOf(@"\") + 1);
}
search.Filter = "(sAMAccountName=" + samaccount + ")";
}
SearchResult result = search.FindOne();
result.Properties["manager"][0];
现在您知道谁是manager了,所以您可以查询有关manager的数据。如果您想使用主体而不是DirectorySearcher,您可以调用UserPrincipal对象上的
GetUnderlineingObject()
,并获取该对象的DirectoryEntry
using(var user = new UserPrincipal(domainContext))
{
DirectoryEntry dEntry = (DirectoryEntry)user.GetUnderlyingObject();
Object manager = dEntry.Properties["manager"][0];
}
我使用DirectorySearcher和PrincipalSearcher组合返回唯一标识符sAMAccountName,这样我就可以从AD获取所有信息
广告经理?这是什么?与用户关联的广告经理…从未听说过。这很奇怪,因为我使用AD大约2年了。当使用此方法时,我在获取基础对象时收到一个错误,声明“必须先保留主对象,然后才能调用此方法。”。有什么想法吗?@DaRoGa我相信你已经找到了答案,但是在初始化
PrincipalContext
类时,一定要指定你的域。我还使用了UserPrincipal.FindByIdentity(context,IdentityType.SamAccountName,username)
而不是newuserprincipal(domainContext)
。这对我来说很有效,因为在处理了上述代码之后,我收到了一个不同的错误。
public string GetManagerId(string id)
{
string managerNetId = "Not_Found";
try
{
using (DirectorySearcher searcher = new DirectorySearcher(Context.LdapConnection))
{
//We search known user Id
searcher.Filter = "(sAMAccountName=" + id + ")";
//We search Manager Property
searcher.PropertiesToLoad.Add("manager");
SearchResult result = searcher.FindOne();
string DistingedName = result.Properties["manager"][0].ToString();
// We create domain context
PrincipalContext PrContext = new PrincipalContext(ContextType.Domain, "YourDomain.com", "OU=Users,OU=****,OU=****,OU=****,DC=*****,DC=*****");
//We define a "query-by-example" principal - here, we search for a UserPrincipal
UserPrincipal qbeUser = new UserPrincipal(PrContext);
// We define parameter for search operation
string mngt = DistingedName.Trim();
qbeUser.Surname = mngt.Substring(mngt.IndexOf("=") + 1, mngt.IndexOf(",") - 4).ToLower();
string fnm = mngt.Insert(1, "\\,");
qbeUser.GivenName = fnm.Substring(mngt.IndexOf(",") + 4, mngt.IndexOf(",") - 5).ToLower() + "*";
// create your principal searcher passing in the QBE principal
PrincipalSearcher srch = new PrincipalSearcher(qbeUser);
// find all matches
foreach (var found in srch.FindAll())
{
// We check if is realy user Manager
if (found.DistinguishedName == DistingedName)
{
managerNetId = found.SamAccountName;
}
}
return managerNetId;
}
}
catch (Exception ex)
{
Console.WriteLine(ex.Message);
return null;
}
}
public string GetManagerMail(string managerNetId)
{
try
{
using (DirectorySearcher searcher = new DirectorySearcher(Context.LdapConnection))
{
searcher.Filter = "(sAMAccountName=" + id + ")";
searcher.PropertiesToLoad.Add("mail");
SearchResult result = searcher.FindOne();
return result.Properties["mail"][0].ToString();
}
}
catch (Exception)
{
return null;
}
}