您的位置:首页 > 其它

jndi操作Ldap进行增删改查

2013-07-03 15:18 369 查看
由于是第一次操作Ldap 网上各种查资料,然后自己总结了一点

首先要获取Ldap连接

连接Ldap做操作需要一些必要的参数 其实跟jdbc连接数据库差不多 下面是返回一个ldap连接 (由于我的需求是做同步数据,连接的URL之类的属性都是不一样的,也都是从配置文件中读取,所以增删改查的方法都用到了获取连接的方法)

/**
* 连接LDAP
* @param uLdapURL连接URL
* @param searchDN需要查询的节点DN
* @return Ldap连接
*/
public static LdapContext ConnLdap(String uLdapURL, String username,
String password) {
Hashtable<String, Object> env = new Hashtable<String, Object>();
env.put(Context.INITIAL_CONTEXT_FACTORY,"com.sun.jndi.ldap.LdapCtxFactory");
env.put(Context.PROVIDER_URL, uLdapURL);     
env.put(Context.SECURITY_AUTHENTICATION, "simple");
env.put(Context.SECURITY_PRINCIPAL, username);
env.put(Context.SECURITY_CREDENTIALS, password);
LdapContext ctx = null;
try {
ctx = new InitialLdapContext(env, null);
} catch (NamingException e) {
System.out.println("Lookup failed: " + e);
}
return ctx;
}

/**

 * 根据指定的节点查询

* @param searchDN同步节点

* @return 需要同步的帐号信息

*/
public List searchInfoByDN(String searchDN) {
List list = new ArrayList();
try {
LdapContext ctx = this.ConnLdap(InitialConf.uLDAP_URL,InitialConf.uuName, InitialConf.uPWD);
NamingEnumeration objs = ctx.search(searchDN, null);
Map<String, Object> map = null;
while (objs.hasMoreElements()) {
SearchResult match = (SearchResult) objs.nextElement();
System.out.println(match.getName());
Attributes attrs = match.getAttributes();
NamingEnumeration e = attrs.getAll();
map = new HashMap<String, Object>();
while (e.hasMoreElements()) {
Attribute attr = (Attribute) e.nextElement();
System.out.println(attr.getID());
if (attr.size() > 1) {
Object[] objclass = new String[attr.size()];
for (int i = 0; i < attr.size(); i++) {
objclass[i] = attr.get(i);
}
map.put(attr.getID(), objclass);
} else {
map.put(attr.getID(), attr.get(0));
}
}
list.add(map);
}
} catch (NamingException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return list;
}

/**
* 删除指点节点数据
* @param dn
* @return
*/
public boolean deleteInformation(String dn) {
try {
LdapContext ctx = this.ConnLdap(InitialConf.uLDAP_URL,InitialConf.uuName, InitialConf.uPWD);
ctx.destroySubcontext("cn=aaa,ou=People");
return true;
} catch (NamingException ne) {
System.err.println("Error: " + ne.getMessage());
return false;
}
}

/**
* 用于修改
* @param dn
* @return
*/
public boolean modifyInformation(String dn) {
try {
LdapContext ctx = this.ConnLdap(InitialConf.uLDAP_URL,InitialConf.uuName, InitialConf.uPWD);
ModificationItem[] mods = new ModificationItem[2];
Attribute mobilePhone = new BasicAttribute("mobilePhone", "12315");
Attribute employeeName = new BasicAttribute("employeeName", "Smith");
mods[0] = new ModificationItem(DirContext.ADD_ATTRIBUTE,mobilePhone);
mods[1] = new ModificationItem(DirContext.REPLACE_ATTRIBUTE,employeeName);
ctx.modifyAttributes(dn, mods);
return true;
} catch (NamingException ne) {
System.err.println("Error: " + ne.getMessage());
return false;
}
}

/**
* 增加信息

* @param list 
*/

public void addToLdap(List list) {
LdapContext ctx = this.ConnLdap(InitialConf.fLDAP_URL,InitialConf.fuName, InitialConf.fPWD);
try {
if (list != null && list.size() > 0) {
for (int i = 0; i < list.size(); i++) {
Map map = (Map) list.get(i);
Set set = map.keySet();
Iterator iterator = set.iterator();
String cn = (String) map.get("cn");

Attributes attrs = new BasicAttributes();
Attribute oneAttr = null;
while (iterator.hasNext())
b0bd
{
String key = (String) iterator.next();
oneAttr = new BasicAttribute(key);
oneAttr.add(map.get(key));
attrs.put(oneAttr);
}
Attribute objClasses = new BasicAttribute("objectclass");
objClasses.add("top");
objClasses.add("simp-obj");
objClasses.add("organizationalperson");
objClasses.add("person");
objClasses.add("simp-person");
attrs.put(objClasses);
ctx.createSubcontext("cn=" + cn + "," + "ou=People", attrs);
}
}
} catch (NamingException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  LDAP