本文目錄一覽:
Java獲取Ldap葉子節點
使用netscape的ldap工具包。使用其它的工具包,寫法類似。
註:必須知道base dn,以下假定ou=admin為base dn。若有明確的base dn,那寫法比如:ou=admin,o=test1
源代碼如下:
==========================
import netscape.ldap.*;
public class SearchTest {
public static void main(String[] args) {
LDAPConnection lc = null;
LDAPEntry findEntry = null;
int status = -1;
try {
// lc = ConnectionPool.
lc = new LDAPConnection();
/* Connect to server */
String MY_HOST = “localhost”;
int MY_PORT = 389;
lc.connect(MY_HOST, MY_PORT);
System.out.println(“1=========” +lc.isConnected());
lc.authenticate(“cn=Directory Manager”,”password”);
System.out.println(“2=========” +lc.isConnected());
/* search for all entries with surname of Jensen */
String MY_FILTER = “(objectclass=*)”;
String MY_SEARCHBASE = “ou=admin”;
LDAPSearchConstraints cons = lc.getSearchConstraints();
cons.setBatchSize(0);
cons.setMaxResults(5);
MY_FILTER = “(objectclass=*)” ;
LDAPSearchResults res = lc.search(MY_SEARCHBASE,
LDAPConnection.SCOPE_ONE,
MY_FILTER,
null,
false,
cons);
while (res.hasMoreElements()) {
LDAPEntry cLDAPEntry = res.next() ;
System.out.println(“” + cLDAPEntry.getDN());
System.out.println(“” + cLDAPEntry.toString());
}
status = 0;
} catch (LDAPException e) {
System.out.println(“Error: ” + e.toString());
e.printStackTrace();
}
/* Done, so disconnect */
if ((lc != null) lc.isConnected()) {
try {
lc.disconnect();
System.out.println(“3=========” +lc.isConnected());
} catch (LDAPException e) {
System.out.println(“Error: ” + e.toString());
}
}
System.out.println(“4=========” +lc.isConnected());
System.exit(status);
}
}
LDAP在JAVA中如何模糊查詢
/** * 獲得LDAP連接(不通過連接池,直接獲得連接) * @return * @throws Exception */ private javax.naming.directory.DirContext getDirContext() throws Exception { DirContext ctx = null; java.util.Hashtable env = new java.util.Hashtable(); env.put(Context.INITIAL_CONTEXT_FACTORY, “com.sun.jndi.ldap.LdapCtxFactory”); env.put(Context.PROVIDER_URL, “ldap://localhost:389”); env.put(Context.SECURITY_AUTHENTICATION, “simple”); env.put(Context.SECURITY_PRINCIPAL, user); env.put(Context.SECURITY_CREDENTIALS, pwd); ctx = new InitialDirContext(env); return ctx; } /** * 返回用戶查詢接口 * @param DN 查找範圍 ou=test,dc=abcd,dc=com * @param filter 過濾條件 cn=* * @param myserach 搜索範圍 * @return LDAP標準接口 * @throws Exception */ public javax.naming.NamingEnumeration getFilter(String DN,String filter,int myserach) throws Exception { DirContext ctx = getDirContext(); try { NamingEnumeration em; SearchControls con = new SearchControls(); con.setSearchScope(myserach); em = ctx.search(DN, filter, con); return em; } finally { // } } /** * 設置條件查找 * @param dn 查找的根結點 * @param filter 查找條件 * @param level 查找範圍 * @return 返回一個由DN組成的JAVA STRING 列表 * @throws Exception */ public java.util.Vector getfilterNodes(String dn,String filter,int level) throws Exception { java.util.Vector ve=new java.util.Vector(); NamingEnumeration em=getFilter(dn,filter,level); while(em!=null em.hasMoreElements()) { SearchResult rs=(SearchResult)em.nextElement(); String db=rs.getName(); if (db.trim().equals(“”)) ve.add(dn); else ve.add(db+”,”+dn); } return ve; }
關於ldap java驗證的問題
我寫過這類代碼,與你這段代碼有些不一樣。
env.put(Context.SECURITY_AUTHENTICATION, “none”);這段中我指定他的認證方式是”simple”,也就是採用用戶名/密碼的方式認證,我也不是很清楚採用none是否能夠成功認證。
認證用的用戶名應該要寫全,你需要查看每一個上級節點的屬性,打個比方,IS是CN,FADU是DC,funo.com.cn是DC,那你的認證用戶名就應該是:
DC=funo.com.cn,DC=FADU,CN=IS,CN=caiwei
你先試一下吧,還有問題再討論,令附上LDAP ERROR CODE:
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/186325.html