AD域的Java开发操作

简介:
  1. import java.util.ArrayList;  
  2. import java.util.HashMap;  
  3. import java.util.Hashtable;  
  4. import java.util.List;  
  5. import java.util.Map;  
  6. import javax.naming.Context;  
  7. import javax.naming.NamingEnumeration;  
  8. import javax.naming.directory.Attributes;  
  9. import javax.naming.directory.SearchControls;  
  10. import javax.naming.directory.SearchResult;  
  11. import javax.naming.ldap.InitialLdapContext;  
  12. import javax.naming.ldap.LdapContext;  
  13.   
  14. /** 
  15.  * LDAP 连接 
  16.  */  
  17. public class LDAPConnection {  
  18.   
  19.     private String baseDN;  
  20.     private String filter;  
  21.     private String[] attributes;  
  22.     private Hashtable<String, String> env = null;  
  23.   
  24.     private static LDAPConnection lc;  
  25.   
  26.     private LDAPConnection() {  
  27.   
  28.         //搜索根节点  
  29.         baseDN = "******";  
  30.         //要查询的属性列  
  31.         attributes = new String[]{"cn"};  
  32.         //过滤条件  
  33.         if ((filter == null) || (filter == ""))  
  34.             filter = "objectclass=*";  
  35.     }  
  36.   
  37.     public static LDAPConnection getInstance() {  
  38.         if (lc == null) {  
  39.             lc = new LDAPConnection();  
  40.         }  
  41.         return lc;  
  42.     }  
  43.   
  44.     /** 
  45.      * 建立LDAP连接 
  46.      * @return boolean 
  47.      */  
  48.     private LdapContext getLdapContext() {  
  49.         env = new Hashtable<String, String>();  
  50.         env.put(Context.INITIAL_CONTEXT_FACTORY, "com.sun.jndi.ldap.LdapCtxFactory");  
  51.         env.put(Context.PROVIDER_URL, "ldap://*****:389");  
  52.         env.put(Context.SECURITY_AUTHENTICATION, "simple");  
  53.         env.put(Context.SECURITY_CREDENTIALS, "123456");  
  54.         env.put(Context.SECURITY_PRINCIPAL, "****");  
  55.         try {  
  56.             return new InitialLdapContext(env, null);  
  57.         } catch (Exception e) {  
  58.             System.out.println("连接服务器失败!");  
  59.             e.printStackTrace();  
  60.         }  
  61.         return null;  
  62.     }  
  63.     /**  
  64.      * 获取用户信息  
  65.      * @return List<Map>  
  66.      */  
  67.     public List<Map> getUsers() {  
  68.           
  69.         LdapContext ctx = getLdapContext();  
  70.         if(ctx == null){  
  71.             return null;  
  72.         }  
  73.         List<Map> list = new ArrayList<Map>();  
  74.         try {  
  75.             SearchControls constraints = new SearchControls();  
  76.             constraints.setReturningAttributes(attributes);  
  77.             constraints.setSearchScope(SearchControls.SUBTREE_SCOPE);  
  78.             NamingEnumeration<?> en = ctx.search(baseDN, filter, constraints);  
  79.   
  80.             while (en != null && en.hasMoreElements()) {  
  81.                 Object obj = en.nextElement();  
  82.                 if (obj instanceof SearchResult) {  
  83.   
  84.                     SearchResult si = (SearchResult) obj;  
  85.   
  86.                     Attributes attrs = si.getAttributes();  
  87.                     Map<String, Object> map = new HashMap<String, Object>();  
  88.                     for (int i = 0; i < attributes.length; i++) {  
  89.                         String attributeName = attributes[i];  
  90.   
  91.                         if(attrs.get(attributeName) == null){  
  92.                             map.put(attributeName, attrs.get(attributeName));  
  93.                         }else{  
  94.                             map.put(attributeName, attrs.get(attributeName).get());  
  95.                         }  
  96.                     }  
  97.                     System.out.println(map);  
  98.                     list.add(map);  
  99.                 } else {  
  100.                     System.out.println(obj);  
  101.                 }  
  102.             }  
  103.         } catch (Exception e) {  
  104.             e.printStackTrace();  
  105.         }  
  106.         System.out.println("总符合条件记录数:"+list.size());  
  107.         return list;  
  108.     }  
  109.   
  110.     public static void main(String arg[]) {  
  111.         LDAPConnection.getInstance().getUsers();  
  112.     }  
  113.   
  114. }  
相关文章
|
23天前
|
Java API Maven
如何使用Java开发抖音API接口?
在数字化时代,社交媒体平台如抖音成为生活的重要部分。本文详细介绍了如何用Java开发抖音API接口,从创建开发者账号、申请API权限、准备开发环境,到编写代码、测试运行及注意事项,全面覆盖了整个开发流程。
69 10
|
21天前
|
监控 Java API
如何使用Java语言快速开发一套智慧工地系统
使用Java开发智慧工地系统,采用Spring Cloud微服务架构和前后端分离设计,结合MySQL、MongoDB数据库及RESTful API,集成人脸识别、视频监控、设备与环境监测等功能模块,运用Spark/Flink处理大数据,ECharts/AntV G2实现数据可视化,确保系统安全与性能,采用敏捷开发模式,提供详尽文档与用户培训,支持云部署与容器化管理,快速构建高效、灵活的智慧工地解决方案。
|
2月前
|
监控 Java 测试技术
Java开发现在比较缺少什么工具?
【10月更文挑战第15天】Java开发现在比较缺少什么工具?
36 1
|
11天前
|
Java 开发者 微服务
Spring Boot 入门:简化 Java Web 开发的强大工具
Spring Boot 是一个开源的 Java 基础框架,用于创建独立、生产级别的基于Spring框架的应用程序。它旨在简化Spring应用的初始搭建以及开发过程。
27 6
Spring Boot 入门:简化 Java Web 开发的强大工具
|
3天前
|
算法 Java API
如何使用Java开发获得淘宝商品描述API接口?
本文详细介绍如何使用Java开发调用淘宝商品描述API接口,涵盖从注册淘宝开放平台账号、阅读平台规则、创建应用并申请接口权限,到安装开发工具、配置开发环境、获取访问令牌,以及具体的Java代码实现和注意事项。通过遵循这些步骤,开发者可以高效地获取商品详情、描述及图片等信息,为项目和业务增添价值。
32 10
|
6天前
|
JavaScript 安全 Java
java版药品不良反应智能监测系统源码,采用SpringBoot、Vue、MySQL技术开发
基于B/S架构,采用Java、SpringBoot、Vue、MySQL等技术自主研发的ADR智能监测系统,适用于三甲医院,支持二次开发。该系统能自动监测全院患者药物不良反应,通过移动端和PC端实时反馈,提升用药安全。系统涵盖规则管理、监测报告、系统管理三大模块,确保精准、高效地处理ADR事件。
|
22天前
|
开发框架 Java 关系型数据库
Java哪个框架适合开发API接口?
在快速发展的软件开发领域,API接口连接了不同的系统和服务。Java作为成熟的编程语言,其生态系统中出现了许多API开发框架。Magic-API因其独特优势和强大功能,成为Java开发者优选的API开发框架。本文将从核心优势、实际应用价值及未来展望等方面,深入探讨Magic-API为何值得选择。
29 2
|
23天前
|
监控 前端开发 Java
【技术开发】接口管理平台要用什么技术栈?推荐:Java+Vue3+Docker+MySQL
该文档介绍了基于Java后端和Vue3前端构建的管理系统的技术栈及功能模块,涵盖管理后台的访问、登录、首页概览、API接口管理、接口权限设置、接口监控、计费管理、账号管理、应用管理、数据库配置、站点配置及管理员个人设置等内容,并提供了访问地址及操作指南。
|
22天前
|
IDE Java 编译器
开发 Java 程序一定要安装 JDK 吗
开发Java程序通常需要安装JDK(Java Development Kit),因为它包含了编译、运行和调试Java程序所需的各种工具和环境。不过,某些集成开发环境(IDE)可能内置了JDK,或可使用在线Java编辑器,无需单独安装。
48 1
|
29天前
|
SQL 安全 Java
安全问题已经成为软件开发中不可忽视的重要议题。对于使用Java语言开发的应用程序来说,安全性更是至关重要
在当今网络环境下,Java应用的安全性至关重要。本文深入探讨了Java安全编程的最佳实践,包括代码审查、输入验证、输出编码、访问控制和加密技术等,帮助开发者构建安全可靠的应用。通过掌握相关技术和工具,开发者可以有效防范安全威胁,确保应用的安全性。
48 4