网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > Java
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
网络编程:ASP教程,ASP.NET教程,PHP教程,JSP教程,C#教程,数据库,XML教程,Ajax,Java,Perl,Shell,VB教程,Delphi,C/C++教程,软件工程,J2EE/J2ME,移动开发
本月文章推荐
.利用jdom实现读取数据库生成XML及.
.浅析Spring提供的事务管理方法.
.学习深入Java 1.5枚举类型的内部.
.虚拟机概论(六)——JAVA虚拟机.
.数据库中数据项变化不定,如何设.
.Spring入门指引之理解Spring的打.
.JSF与WEB完美应用组合 高度提升开.
.Java 理论与实践: 哈希.
.J2ME配置全攻略.
.isNaN 方法.
.JAVA规则基本篇.
.Jakarta Tapestry 4.0 RC 1.
.详细解析 JavaBeans 与 Ejb 的区.
.《java深度历险》读书笔记(一).
.getItem 方法.
.有效地记录日志简化企业的开发过.
.JSTL 入门:探讨如何利用 core 库.
.轻量组件与重量组件的比较.
.WebLogic 9新特性:Web Services(.
.解决目前web开发的页面程序.

封装JNDI操作LDAP服务器的工具类(2)

发表日期:2008-1-5



  目标:使用者只需要会使用List,Map 数据结构,将对LDAP的操作进行封装
  
  类:主要有三个类
  
  1 Env类 包含LDAP的连接信息
  
  2 LdapConnectionFactory类 ldap连接工厂,提供初始化及获取ldap连接的方法
  
  3 LdapOperUtils ldap的处理工具类,提供了各种操作ldap的方法。
  
  ldap连接工厂,提供初始化ldap连接的方法
  
  package com.common.ldapconnection;
  
  import Java.util.Properties;
  import javax.naming.Context;
  import javax.naming.NamingException;
  import javax.naming.Directory.DirContext;
  import javax.naming.directory.InitialDirContext;
  import org.apache.log4j.Logger;
  import org.apache.commons.lang.StringUtils;
  
  /**
  * 功能描述:ldap连接工厂,提供初始化ldap连接的方法。
  * @author liaowufeng
  * @version 1.0
  */
  public class LdapConnectionFactory {
  // 初始化日志处理类
  static Logger log = Logger.getLogger(LdapConnectionFactory.class.getName());
  
  /**
  * 构造函数私有,防止实例化
  */
  private LdapConnectionFactory() {
  }
  
  /**
  * 从LDAP连接池中取得一个连接
  * @param poolName String 连接池名
  * @env  连接LDAP的连接信息
  * @return DirContext
  */
  public static DirContext getDirContext(String poolName,Env env) {
  // 取得Context
  try {
  // 日志打印,表明进入此方法
  log.debug(Constants.INTOMETHOD + "getDirContext");
  // 初始化Properties对象
  Properties mEnv = new Properties();
  // 使用LDAP/AD的认证方式
  mEnv.put(Context.AUTHORITATIVE, "true");
  // 使用连接池
  mEnv.put("com.sun.jndi.ldap.connect.pool", "true");
  // 设定LDAP/AD的连接工厂
  mEnv.put(Context.INITIAL_CONTEXT_FACTORY, env.factory);
  // 设定LDAP/AD的url地址
  mEnv.put(Context.PROVIDER_URL, env.url);
  // 设定连接TimeOut
  if(!StringUtils.isEmpty(env.timeOut)) {
  mEnv.put("com.sun.jndi.ldap.connect.timeout", env.timeOut);
  }
  // 设定安全模式为simple方式
  mEnv.put(Context.SECURITY_AUTHENTICATION, "simple");
  // ssl通道访问
  if (env != null && "ssl".equals(env.securityProtocol)) {
  // 设定访问协议为ssl
  mEnv.put(Context.SECURITY_PROTOCOL, env.securityProtocol);
  // 设置访问证书属性,若没有此证书将无法通过ssl访问AD
  System.setProperty("javax.net.ssl.trustStore",
  env.sslTrustStore);
  }
  // 读取可以登陆ldap的帐号、密码
  mEnv.put(Context.SECURITY_PRINCIPAL, env.adminUID);
  mEnv.put(Context.SECURITY_CREDENTIALS, env.adminPWD);
  
  log.debug(Constants.INIT + "DirContext");
  // 通过参数连接LDAP/AD
  DirContext ctx = new InitialDirContext(mEnv);
  log.debug("LdapConnectionFactory:" + Constants.INIT + "DirContext" +
  Constants.SUCCESS);
  return ctx;
  
  }
  catch (NamingException ex) {
  ex.printStackTrace();
  log.error("LdapConnectionFactory:" + Constants.INIT + "DirContext" +
  Constants.FAIL);
  log.error(ex.getMessage());
  return null;
  }
  }
  
  /**
  * 关闭LDAP连接
  * @param dirContext DirContext 已连接的LDAP的Context实例
  */
  public static void closeDirContext(DirContext dirContext) {
  try {
  if (dirContext != null)
  dirContext.close();
  }
  catch (Exception ex) {
  ex.printStackTrace();
  log.error("not close DirContext");
  }
  }
  
  
  /**
  * 获取 LDAP 服务器连接的方法
  * @param env 连接LDAP的连接信息
  * @return DirContext - LDAP server的连接
  */
  public static DirContext getDirContext(Env env) {
  try {
  // 初始化Properties对象
  Properties mEnv = new Properties();
  // 使用LDAP/AD的认证方式
  mEnv.put(Context.AUTHORITATIVE, "true");
  // 设定LDAP/AD的连接工厂
  mEnv.put(Context.INITIAL_CONTEXT_FACTORY, env.factory);
  // 设定LDAP/AD的url地址
  mEnv.put(Context.PROVIDER_URL, env.url);
  // 设定连接TimeOut
  if (!StringUtils.isEmpty(env.timeOut)) {
  mEnv.put("com.sun.jndi.ldap.connect.timeout", env.timeOut);
  }
  // 设定安全模式为simple方式
  mEnv.put(Context.SECURITY_AUTHENTICATION, "simple");
  // ssl通道访问
  if (env != null && "ssl".equals(env.securityProtocol)) {
  // 设定访问协议为ssl
  mEnv.put(Context.SECURITY_PROTOCOL, env.securityProtocol);
  // 设置访问证书属性,若没有此证书将无法通过ssl访问AD
  System.setProperty("javax.net.ssl.trustStore",
  env.sslTrustStore);
  }
  // 读取可以登陆ldap的帐号、密码
  mEnv.put(Context.SECURITY_PRINCIPAL, env.adminUID);
  mEnv.put(Context.SECURITY_CREDENTIALS, env.adminPWD);
  
  log.debug(Constants.INIT + "DirContext");
  // 通过参数连接LDAP/AD
  DirContext ctx = new InitialDirContext(mEnv);
  log.debug("LdapConnectionFactory:" + Constants.INIT + "DirContext" +
  Constants.SUCCESS);
  return ctx;
  
  }
  catch (NamingException ex) {
  ex.printStackTrace();
  log.error("LdapConnectionFactory:" + Constants.INIT + "DirContext" +
  Constants.FAIL);
  log.error(ex.getMessage());
  return null;
  }
  }
  }
上一篇:封装JNDI操作LDAP服务器的工具类(5) 人气:688
下一篇:封装JNDI操作LDAP服务器的工具类(3) 人气:639
浏览全部Java的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐