国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

封裝JNDI操作LDAP服務器的工具類(2)

2019-11-18 12:24:24
字體:
來源:轉載
供稿:網友

  目標:使用者只需要會使用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;
  }
  }
  }

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 安吉县| 商洛市| 永定县| 毕节市| 盐城市| 上思县| 隆子县| 涿鹿县| 扎赉特旗| 体育| 边坝县| 信阳市| 漠河县| 榆林市| 临城县| 富源县| 扎鲁特旗| 彭山县| 林西县| 永川市| 屏东市| 慈溪市| 泰和县| 开阳县| 沙湾县| 鹿泉市| 宁城县| 洛隆县| 仪陇县| 鄂州市| 泰宁县| 维西| 延长县| 咸宁市| 丰原市| 贺州市| 抚顺县| 新野县| 乌苏市| 丹东市| 额尔古纳市|