<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    posts - 30,  comments - 85,  trackbacks - 0

     LDAP的英文全稱是Lightweight Directory Access Protocol,一般都簡稱為LDAP。它是基于X.500標準的,但是簡單多了并且可以根據需要定制。與X.500不同,LDAP支持TCP/IP,這對訪問Internet是必須的。LDAP的核心規范在RFC中都有定義,所有與LDAP相關的RFC都可以在LDAPman RFC網頁中找到。現在LDAP技術不僅發展得很快而且也是激動人心的。在企業范圍內實現LDAP可以讓運行在幾乎所有計算機平臺上的所有的應用程序從 LDAP目錄中獲取信息。LDAP目錄中可以存儲各種類型的數據:電子郵件地址、郵件路由信息、人力資源數據、公用密匙、聯系人列表,等等。通過把 LDAP目錄作為系統集成中的一個重要環節,可以簡化員工在企業內部查詢信息的步驟,甚至連主要的數據源都可以放在任何地方。

    以下是對ldap中進行連接,人員的增刪改查的過程。希望對初學者有一定的幫助。

    package net.risesoft.ldap;

    import java.util.Enumeration;
    import java.util.Hashtable;

    import javax.naming.Context;
    import javax.naming.NamingEnumeration;
    import javax.naming.NamingException;
    import javax.naming.directory.Attribute;
    import javax.naming.directory.Attributes;
    import javax.naming.directory.BasicAttribute;
    import javax.naming.directory.BasicAttributes;
    import javax.naming.directory.DirContext;
    import javax.naming.directory.InitialDirContext;
    import javax.naming.directory.ModificationItem;
    import javax.naming.directory.SearchControls;
    import javax.naming.directory.SearchResult;

    public class LdapTest {
     public static void main(String[] args) {
      String account = "admin";
      String password = "1";
      String root = "o=com"; // root

      Hashtable env = new Hashtable();
      env.put(Context.INITIAL_CONTEXT_FACTORY, "com.sun.jndi.ldap.LdapCtxFactory");
      env.put(Context.PROVIDER_URL, "ldap://localhost:389/" + root);
      env.put(Context.SECURITY_AUTHENTICATION, "simple");
      env.put(Context.SECURITY_PRINCIPAL, "cn=" + account + "," + root);
      env.put(Context.SECURITY_CREDENTIALS, password);

      DirContext ctx = null;
      try {
       // 鏈接ldap
       ctx = new InitialDirContext(env);
       System.out.println("ldap認證成功");

       // 3.添加節點
       String newUserName = "user2";
       BasicAttributes attrsbu = new BasicAttributes();
       BasicAttribute objclassSet = new BasicAttribute("objectclass");
       objclassSet.add("person");
       objclassSet.add("top");
       objclassSet.add("organizationalPerson");
       objclassSet.add("inetOrgPerson");
       attrsbu.put(objclassSet);
       attrsbu.put("sn",   newUserName);
       attrsbu.put("uid",   newUserName);
       ctx.createSubcontext("cn=" + newUserName, attrsbu);

       // 5.修改節點
       account = "user2";
       String newDisplayName = "newDisplayName";
       ModificationItem modificationItem[] = new ModificationItem[1];
       modificationItem[0] = new ModificationItem(DirContext.REPLACE_ATTRIBUTE, new BasicAttribute("displayName", newDisplayName));
       ctx.modifyAttributes("cn=" + account, modificationItem);

       // 查詢節點
       SearchControls constraints = new SearchControls();
       constraints.setSearchScope(SearchControls.SUBTREE_SCOPE);
       // constraints.setSearchScope(SearchControls.ONELEVEL_SCOPE);
       NamingEnumeration en = ctx.search("", "cn=user2", constraints); // 查詢所有用戶
       while (en != null && en.hasMoreElements()) {
        Object obj = en.nextElement();
        if (obj instanceof SearchResult) {
         SearchResult si = (SearchResult) obj;
         System.out.println("name:   " + si.getName());
         Attributes attrs = si.getAttributes();
         if (attrs == null) {
          System.out.println("No   attributes");
         } else {
          for (NamingEnumeration ae = attrs.getAll(); ae.hasMoreElements();) {
           Attribute attr = (Attribute) ae.next();
           String attrId = attr.getID();

           for (Enumeration vals = attr.getAll(); vals.hasMoreElements();) {
            System.out.print(attrId + ":   ");
            Object o = vals.nextElement();
            if (o instanceof byte[])
             System.out.println();// new
                   // String((byte[])o)
            else
             System.out.println(o);
           }
          }
         }
        } else {
         System.out.println(obj);
        }
        System.out.println();
       }

       // 4.刪除節點
       account = "user2";
       ctx.destroySubcontext("cn=" + account);

      } catch (javax.naming.AuthenticationException e) {
       System.out.println("認證失敗");
      } catch (Exception e) {
       System.out.println("認證出錯:");
       e.printStackTrace();
      }

      if (ctx != null) {
       try {
        ctx.close();
       } catch (NamingException e) {
        // ignore
       }
      }
      System.exit(0);
     }
    }

    posted on 2007-05-31 14:25 安文豪 閱讀(6967) 評論(4)  編輯  收藏

    FeedBack:
    # re: 一個完整的ldap操作的例子
    2007-06-01 09:06 | popoer
    不知道樓主有沒有ldap排序和分頁的例子?  回復  更多評論
      
    # re: 一個完整的ldap操作的例子[未登錄]
    2008-07-31 12:27 | 過客
    Good  回復  更多評論
      
    # re: 一個完整的ldap操作的例子[未登錄]
    2011-08-02 13:51 | 海風
    多謝分享!  回復  更多評論
      
    # re: 一個完整的ldap操作的例子
    2012-12-17 18:24 |
    謝謝^_^_^  回復  更多評論
      

    只有注冊用戶登錄后才能發表評論。


    網站導航:
     

    <2012年12月>
    2526272829301
    2345678
    9101112131415
    16171819202122
    23242526272829
    303112345

    常用鏈接

    留言簿(6)

    隨筆檔案(28)

    文章分類(3)

    文章檔案(4)

    最新隨筆

    搜索

    •  

    積分與排名

    • 積分 - 86472
    • 排名 - 666

    最新評論

    閱讀排行榜

    評論排行榜

    主站蜘蛛池模板: 免费看国产精品麻豆| 2021国产精品成人免费视频| 美女羞羞免费视频网站| 国产亚洲精品国产福利在线观看 | 亚洲av不卡一区二区三区| 亚洲AV无码精品色午夜果冻不卡| 亚洲伊人久久大香线焦| 偷自拍亚洲视频在线观看99| 在线观看免费亚洲| 亚洲αv久久久噜噜噜噜噜| 99久久精品毛片免费播放| 成人免费毛片内射美女-百度| 四虎永久免费观看| 美女被爆羞羞网站免费| 久久精品国产亚洲7777| 亚洲剧情在线观看| 成年女人毛片免费播放视频m| 中文字幕精品无码亚洲字| 99久久99这里只有免费的精品| 亚洲AV无码精品色午夜果冻不卡| 久久久精品2019免费观看| 亚洲av日韩片在线观看| 亚洲人成电影青青在线播放| 成人毛片18女人毛片免费视频未 | 立即播放免费毛片一级| 亚洲欧洲自拍拍偷精品 美利坚 | 成人免费视频一区| 香港特级三A毛片免费观看| 国产成人综合亚洲AV第一页| 国产亚洲精品第一综合| 亚洲国产精品福利片在线观看| 成人午夜免费视频| 成人永久免费高清| 中文字幕成人免费高清在线视频| 免费一级毛片在线观看| 欧美色欧美亚洲另类二区| 国产免费AV片在线播放唯爱网| 美女露隐私全部免费直播| 亚洲91av视频| 国产精品免费综合一区视频| 亚洲精品国产av成拍色拍|