Ldap Java同步用戶

Java操作LDAP有幾種方法,這裏主要介紹的是JNDI包,就是它:
com.sun.jndi.ldap.LdapCtxFactory
LDAP默認情況下使用的是BDB數據庫,所以呢,操作LDAP就和操作數據庫一樣,要分幾步走:
1、先導入所需的包,如下:
import java.util.ArrayList;
import java.util.Hashtable;
import javax.naming.Context;
import javax.naming.NamingEnumeration;
import javax.naming.directory.Attribute;
import javax.naming.directory.BasicAttribute;
import javax.naming.directory.BasicAttributes;
import javax.naming.directory.InitialDirContext;
import javax.naming.directory.DirContext;
import javax.naming.directory.Attributes;
import javax.naming.directory.ModificationItem;
import javax.naming.directory.SearchResult;
import javax.naming.NamingException;
import com.sun.NET.ssl.internal.ssl.Debug;
2、連接LDAP,得到連接對象,如下:
DirContext ctx = null; //這個就是LDAP的連接對象
Hashtable env = new Hashtable(); //定義一個哈希表來存連接信息

env.put(Context.INITIAL_CONTEXT_FACTORY,”com.sun.jndi.ldap.LdapCtxFactory”); //記錄工JNDI工廠
env.put(Context.PROVIDER_URL, ldap://192.168.0.1:389); //LDAP的地址,要根據LDAP服務器IP進行修改,389是LDAP的默認端口
env.put(Context.SECURITY_AUTHENTICATION, “simple”); //這個是默認授權類型,一般不用改
env.put(Context.SECURITY_PRINCIPAL, “”); //LDAP的賬戶名,一般是這樣的格式:(cn=admin,)dc=cs,dc=hunan,dc=com ,根據LDAP的配置情況來
env.put(Context.SECURITY_CREDENTIALS, “123456”); //對應上面賬戶的密碼

try
{
ctx = new InitialDirContext(env); //初始化LDAP連接,連接成功後就可以用ctx來操作LDAP了
}
catch(NamingException e)
{
e.printStackTrace();
}
這裏建議大家把以上的代碼寫成一個函數,返回DirContext 這個對象,方便使用。
3、連接LDAP後同步某一個組下面的用戶,如下:
Map

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章