操作AD的用户信息(通过LDAP应用)

Posted sleepingdogs

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了操作AD的用户信息(通过LDAP应用)相关的知识,希望对你有一定的参考价值。

  Windows AD是Windows ActiveDirectories的简称,意为活动目录。可以用这个服务,进行用户信息的管理。

       安装AD : http://blog.postcha.com/read/80

代码部分

 

//通过ad域登录
        Hashtable env = new Hashtable();
        env.put(Context.INITIAL_CONTEXT_FACTORY, "com.sun.jndi.ldap.LdapCtxFactory");
        //ad域地址:windos server上输入ipconfig查看,369是固定端口,dc=contoso,dc=com是域的范围
        env.put(Context.PROVIDER_URL, "ldap://172.23.22.241:389");
        //ad域里面的用户
        env.put(Context.SECURITY_PRINCIPAL, "administrator@netfans.com");
        //ad域里面的密码
        env.put(Context.SECURITY_CREDENTIALS, "1qaz@WSX");
        env.put(Context.SECURITY_AUTHENTICATION, "simple");
        DirContext ctx = null;
        NamingEnumeration results = null;
        String st="";
        
        try 
            //登录验证
            ctx = new InitialDirContext(env);
            SearchControls controls = new SearchControls();
            controls.setSearchScope(SearchControls.SUBTREE_SCOPE);
            //根据用户名查看ad域中是否存在当前用户
            //results = ctx.search("dc=netfans,dc=com", "(&(objectclass=person)(userprincipalname=‘administrator‘))", controls);

            String lastSyncTime = "20190904085630.0Z";
            String syncFilter = String.format("(&(objectClass=user)(whenChanged>=%s)(whenCreated>=%s))", lastSyncTime, lastSyncTime);
            results = ctx.search("dc=netfans,dc=com", syncFilter, controls);
            SearchResult searchResult = (SearchResult) results.next();
            Attributes attributes = searchResult.getAttributes();
            System.out.println(new ObjectMapper().writeValueAsString(attributes));
         catch (Exception e) 
            e.printStackTrace();
        

 

  

以上是关于操作AD的用户信息(通过LDAP应用)的主要内容,如果未能解决你的问题,请参考以下文章

LDAP方式连接AD获取用户信息

JAVA使用Ldap操作AD域

Spring 5,从 LDAP (AD) 获取信息

java 同步用户信息到AD域

java ldap - 获取信息是对 AD 的更改

回复技术提问中的一个问题:php如何读取域用户信息? - PHP进阶讨论