zoukankan      html  css  js  c++  java
  • Active Directory如何用C#进行增加、删除、修改、查询用户与组织单位(转)

    http://www.pc123.org/html/net/asp_net/200806/16_3101.html

     

    首先我们来了解一下什么是Active Directory。不用我描述,看以下网址,或在.net自带帮助文档里根据Active Directory关键字一搜,就什么都明白了。

    接下来,我们来看看权限。你可以通过“网上邻居--整个网络--Directory--demain(你的域名)”你就可以看到所有关于域下的信息,粗一看就知道是怎么回事了。
    需要告诉大家的:所有组织单位下的用户都在Users(容器)--Demain Users(组)中
    用代码进行访问时,如果你是域管理员用户,则可以做任何操作,否则,只能查询用户属性。

    private void SearchUser()
    {
    string domainName = "Domain";
    string groupName = "Domain Users";
    string dirmemName="";
    //在Domain Users域用户里取得每个用户名
    System.DirectoryServices.DirectoryEntry group = new System.DirectoryServices.DirectoryEntry("WinNT://" + domainName + "/" + groupName + ",group");
    foreach(Object member in (IEnumerable)group.Invoke("Members"))
    {
    //根据很个用户生成如:"LDAP://OU=套装软体课,OU=系统开发部,OU=资讯服务处,OU=营运支援中心,OU=XX公司,DC=Domain,DC=com,DC=cn"
    System.DirectoryServices.DirectoryEntry dirmem = new System.DirectoryServices.DirectoryEntry(member);
    dirmemName=dirmem.Name;
    string DomainName="Domain";
    string FilterStr = "(sAMAccountname="+dirmemName+")";
    System.DirectoryServices.DirectorySearcher FindMe = new System.DirectoryServices.DirectorySearcher(DomainName);
    FindMe.Filter = FilterStr;
    System.DirectoryServices.SearchResult FindRes = FindMe.FindOne();
    System.DirectoryServices.DirectoryEntry MyUser = FindRes.GetDirectoryEntry();
    string OUPath=MyUser.Parent.Path;
    //找到该用户所在的LDAP:后,由域管理员登录,并取得该用户的所在属性。
    string strFieldsValue="",strFields="";
    System.DirectoryServices.DirectoryEntry myds=new System.DirectoryServices.DirectoryEntry(OUPath,"域管理员名","域管理员密码");
    foreach(System.DirectoryServices.DirectoryEntry tempEntry in myds.Children)
    {
    if(tempEntry.SchemaClassName.ToString() == "user" && tempEntry.Properties["sAMAccountName"].Value.ToString().ToLower()==dirmemName)
    {
    foreach (string propertyName in tempEntry.Properties.PropertyNames )
    {
    string oneNode = propertyName + ": " +
    entry.Properties[propertyName][0].ToString();
    this.Textbox1.Text=oneNode;
    }
    }

    -------------------------------------------

    public void AddUser(string strPath,string Username,string ChineseName)//strPath 增加用户至哪个组织单位如"LDAP://OU=XX公司,DC=Domain,DC=com"帐号、中文名{
    try
    {
    string RootDSE;
    //System.DirectoryServices.DirectorySearcher DSESearcher= new System.DirectoryServices.DirectorySearcher();
    //RootDSE=DSESearcher.SearchRoot.Path;
    //RootDSE="LDAP://DC=Domain,DC=com";
    //RootDSE=RootDSE.Insert(7,"CN=Users,");
    System.DirectoryServices.DirectoryEntry myDE = new System.DirectoryServices.DirectoryEntry(strPath);
    System.DirectoryServices.DirectoryEntries myEntries = myDE.Children;
    // Create a new entry 'Sample' in the container.
    string strname="CN="+ChineseName;
    System.DirectoryServices.DirectoryEntry myDirectoryEntry = myEntries.Add(strname, "user");

    //MessageBox.Show(myDirectoryEntry.SchemaClassName.ToString());
    myDirectoryEntry.Properties["userPrincipalName"].Value=Username;
    myDirectoryEntry.Properties["name"].Value=ChineseName;
    myDirectoryEntry.Properties["samAccountName"].Value=Username;
    myDirectoryEntry.Properties["userAccountControl"].Value =66048; //590336;
    myDirectoryEntry.CommitChanges();
    }


    ----------------------------------------------

    private void addOU(string strPath,string OUName)//增加组织到strPath组织单位下,组织名称
    {
    try
    {
    //String RootDSE;
    //System.DirectoryServices.DirectorySearcher DSESearcher= new System.DirectoryServices.DirectorySearcher();
    //RootDSE=DSESearcher.SearchRoot.Path;
    //RootDSE="LDAP://OU=百意时尚广场,DC=Domain,DC=com";

    System.DirectoryServices.DirectoryEntry myDE = new System.DirectoryServices.DirectoryEntry(strPath);
    System.DirectoryServices.DirectoryEntries myEntries = myDE.Children;
    string name="OU="+OUName;
    System.DirectoryServices.DirectoryEntry myDirectoryEntry = myEntries.Add(name,"organizationalUnit");

    myDirectoryEntry.Properties["name"].Value=OUName;
    myDirectoryEntry.Properties["instanceType"].Value=4;
    myDirectoryEntry.Properties["distinguishedName"].Value="OU="+OUName+",DC=Domain,DC=COM)";
    myDirectoryEntry.Properties["objectCategory"].Value="CN=Organizational-Unit,CN=Schema,CN=Configuration,DC=sedep,DC=COM";
    myDirectoryEntry.Properties["ou"].Value=OUName;
    myDirectoryEntry.Properties["postalCode"].Value="777";

    myDirectoryEntry.CommitChanges();
    //UserMoveto("LDAP://OU="+OUName+",DC=sedep,DC=com",strPath);
    }
    catch(Exception RaiseErr)

  • 相关阅读:
    《魏坤琳的科学育儿宝典》笔记
    大千世界中,万物皆有时节
    心里健康基本要素
    不带评论的观察是人类智力的最高形式
    《七律·人民解放军占领南京》
    《最好的防御就是进攻》-- 向任总汇报无线业务会议纪要 2013年9月5日
    《深淘滩,低作堰》-- 任正非在运作与交付体系奋斗表彰大会上的讲话 2009年4月24日
    《市场经济是最好的竞争方式,经济全球化是不可阻挡的潮流》-- 任正非在财经系统表彰大会上的讲话 2009年3月24日
    《开放、妥协与灰度》-- 任正非在2009年全球市场工作会议上的讲话 2009年1月15日
    《让青春的火花,点燃无愧无悔的人生》-- 任正非在无线产品线奋斗大会上的讲话纪要 2008年5月31日
  • 原文地址:https://www.cnblogs.com/Hdsome/p/1393160.html
Copyright © 2011-2022 走看看