Java使用LdAP获取AD域用户

java

/**

* @Description:

*

* @Title: LdAPTest.java

* @Package com.joyce.itext.main

* @Copyright: Copyright (c) 2014

*

* @author Comsys-LZP

* @date 2014-8-7 上午10:20:22

* @version V2.0

*/

package com.joyce.itext.main;

import java.util.Properties;

import javax.naming.Context;

import javax.naming.NamingEnumeration;

import javax.naming.NamingException;

import javax.naming.directory.SearchControls;

import javax.naming.directory.SearchResult;

import javax.naming.ldap.InitialLdapContext;

import javax.naming.ldap.LdapContext;

/**

* @Description:拉取AD域账户*/

public class LdAPTest {

public static void main(String[] args) {

Properties env = new Properties();

String adminName = "administrator@2003.com";//username@domain

String adminPassword = "admin";//password

String ldapURL = "LDAP://10.10.2.153:389";//ip:port

env.put(Context.INITIAL_CONTEXT_FACTORY,"com.sun.jndi.ldap.LdapCtxFactory");

env.put(Context.SECURITY_AUTHENTICATION, "simple");//"none","simple","span"

env.put(Context.SECURITY_PRINCIPAL, adminName);

env.put(Context.SECURITY_CREDENTIALS, adminPassword);

env.put(Context.PROVIDER_URL, ldapURL);

try {

LdapContext ctx = new InitialLdapContext(env, null);

SearchControls searchCtls = new SearchControls();

searchCtls.setSearchScope(SearchControls.SUBTREE_SCOPE);

String searchFilter = "(&(objectCategory=person)(objectClass=user)(name=*))";

String searchBase = "DC=2003,DC=com";

String returnedAtts[] = {"memberOf"};

searchCtls.setReturningAttributes(returnedAtts);

NamingEnumeration<SearchResult> answer = ctx.search(searchBase, searchFilter,searchCtls);

while (answer.hasMoreElements()) {

SearchResult sr = (SearchResult) answer.next();

System.out.println("<<<::[" + sr.getName()+"]::>>>>");

}

ctx.close();

}catch (NamingException e) {

e.printStackTrace();

System.err.println("Problem searching directory: " + e);

}

}

}

以上是 Java使用LdAP获取AD域用户 的全部内容, 来源链接: utcz.com/z/394671.html

回到顶部