java直接访问JNDI工具代码
import java.sql.*;
import java.util.*;
import javax.naming.*;
import javax.sql.DataSource;
public class SqlAccess {
//数据库连接
public Connection conn = null;
//结果集
private ResultSet rs = null;
//数据库访问段
public Statement stmt = null;
//是否连接数据库
private boolean isConnDB = false;
private boolean isDefault = true;
private String newDSName = null;
public static HashMap logmap = new HashMap();
public static int begincont = 0;
private int count = 0;
public String serverType="";
public String jndiName = "";
public static final String WLS_INITIAL_CONTEXT_FACTORY = "weblogic.jndi.WLInitialContextFactory";
public static final String TBJBOSS_INITIAL_CONTEXT_FACTORY = "org.jboss.naming.JNDIView";
public static final String WEBSPHERE_INITIAL_CONTEXT_FACTORY = "com.ibm.websphere.naming.WsnInitialContextFactory";
public SqlAccess() {
try {
initial();
conn.setAutoCommit(true);
}
catch (Exception exp) {
}
}
public SqlAccess(String jndi,String serverType) {
this.serverType = serverType;
this.jndiName = jndi;
try {
initial();
conn.setAutoCommit(true);
}
catch (Exception exp) {
}
}
public static SqlAccess createConn(String ds) throws Exception {
SqlAccess sq = new SqlAccess(ds,"websphere");
if (sq == null || sq.conn == null)
throw new Exception("Errorx");
return sq;
}
public static SqlAccess createConn() throws Exception {
return createConn("");
}
public static void main(String[] args) {
}
public static final String ST_WEBSPHERE = "websphere";
public static final String ST_WEBLOGIC = "weblogic";
public static final String ST_TOMCAT = "tomcat";
public static final String ST_JBOSS = "jboss";
public static final String ST_RESIN = "resin";
public void initial() throws SQLException {
try {
Context ctx = null;
DataSource ds = null;
String dsName = this.jndiName;
try {
count = ++begincont;
}
catch (Exception e) {
begincont = 0;
count = ++begincont;
}
System.out.println("[count]"+count);
if (ST_WEBLOGIC.equals(serverType)) {
Properties props = new Properties();
//取数据库连接
props.put("weblogic.codeset", "GBK");
Hashtable parms = new Hashtable();
parms.put( Context.INITIAL_CONTEXT_FACTORY, this.WLS_INITIAL_CONTEXT_FACTORY);
ctx = new InitialContext(parms);
}
else if (ST_JBOSS.equals(serverType)) {
System.out.println("Jboss connection init");
ctx = new InitialContext();
dsName = "java:/" + dsName;
}
else if (ST_RESIN.equals(serverType)) {
System.out.println("Resin Connection init");
ctx = new InitialContext();
dsName = "java:comp/env/" + dsName;
}
else if (ST_WEBSPHERE.equals(serverType)) {
System.out.println("Websphere Connection init");
Hashtable prop = new Hashtable();
prop.put(Context.INITIAL_CONTEXT_FACTORY,this.WEBSPHERE_INITIAL_CONTEXT_FACTORY);
ctx = new InitialContext(prop);
}
else if (ST_TOMCAT.equals(serverType)) {
System.out.println("Tomcat JNDI Connection init");
ctx = new InitialContext();
dsName = "java:comp/env/" + dsName;
}
System.out.println("[SqlAccess]dsName:" + dsName + "...");
ds = (DataSource) ctx.lookup(dsName);
conn = ds.getConnection();
//--System.out
System.out.println("conn:" + conn.toString());
logmap.put(conn,count+"");
//--System.out
System.out.println("ConnectionPool:making a connection...[" + count + "]");
//--System.out
//--System.out
//stmt = conn.createStatement();
isConnDB = true;
}
catch (SQLException sqle) {
sqle.printStackTrace();
System.out.println("SQLException during connection(): " + sqle.getMessage());
throw sqle;
}
catch (Exception e) {
e.printStackTrace();
System.out.println(e.getMessage());
}
}
//设置AutoCommit
public void setAutoCommit(boolean autoCommit) throws SQLException {
try {
if (isConnDB)
conn.setAutoCommit(autoCommit);
}
catch (SQLException sqle) {
System.out.println("SQLException during autoCommit(): " + sqle.getMessage());
throw sqle;
}
catch (Exception e) {
System.out.println(e.getMessage());
}
}
//执行Commit命令
public void commit() throws SQLException {
try {
if (isConnDB)
conn.commit();
}
catch (SQLException sqle) {
System.out.println("SQLException during commit(): " + sqle.getMessage());
throw sqle;
}
catch (Exception e) {
System.out.println(e.getMessage());
}
}
//执行Rollback命令
public void rollback() {
try {
if (isConnDB)
conn.rollback();
}
catch (SQLException sqle) {
System.out.println("SQLException during rollback(): " + sqle.getMessage());
//throw sqle;
}
catch (Exception e) {
System.out.println(e.getMessage());
}
}
//查询与数据库之间的连接是否关闭,true - 有连接:false - 没连接
public boolean isConnectDB() {
return isConnDB;
}
//关闭连接
public void close() {
try {
if (conn != null)
conn.close();
logmap.remove(conn);
logmap.remove("" + count);
System.out.println("ConnectionPool::Closing connection...[" + count + "]\n");
}
catch (SQLException sqle) {
System.out.println("SQLException during close(): " + sqle.getMessage());
//throw sqle;
}
catch (Exception e) {
System.out.println(e.getMessage());
}
}
//public static String SERVER="JBOSS";
//public static String SERVER="WEBLOGIC";
/**
* Returns the logmap.
* @return HashMap
*/
public static HashMap getLogmap() {
return logmap;
}
/**
* Returns the count.
* @return int
*/
public int getCount() {
return count;
}
}
使用此方法获取连接,需要从容器中配置连接池
调用方法演示:
SqlAccess sa = new SqlAccess("HIS", "websphere");
if (sa != null) {
System.out.println("成功连接=" + sa.conn);
} else {
System.out.println("失败连接=" + sa.conn);
}
Connection hisConn = sa.conn;
java直接访问JNDI工具代码的更多相关文章
- java获取时间整点工具代码
/**获取上n个小时整点小时时间 * @param date * @return */ public static String getLastHourTime(Date date,int n){ C ...
- 使用poco 的NetSSL_OpenSSL 搭建https 服务端,使用C++客户端,java 客户端访问,python访问(python还没找到带证书访问的代码.)
V20161028 由于项目原因,需要用到https去做一些事情. 这儿做了一些相应的研究. 这个https 用起来也是折腾人,还是研究了一周多+之前的一些积累. 目录 1,java client 通 ...
- java服务器访问其他服务器工具类编写
java服务器访问其他服务器工具类编写适合各种消息推送及微服务交互 package com.xiruo.medbid.components; import com.xiruo.medbid.util. ...
- 【JAVA系列】使用JavaScript实现网站访问次数统计代码
公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[JAVA系列]使用JavaScript实现网站 ...
- Java中常用的设计模式代码与理解
Java中常用的设计模式代码与理解 一.单例模式 1.饿汉式 (太饿了,类加载的时候就创建实例) /** * 饿汉式单例模式 */ public class HungrySingleInstance ...
- Java并发包同步工具之Exchanger
前言 承接上文Java并发包同步工具之Phaser,讲述了同步工具Phaser之后,搬家博客到博客园了,接着未完成的Java并发包源码探索,接下来是Java并发包提供的最后一个同步工具Exchange ...
- Java安全之JNDI注入
Java安全之JNDI注入 文章首发:Java安全之JNDI注入 0x00 前言 续上篇文内容,接着来学习JNDI注入相关知识.JNDI注入是Fastjson反序列化漏洞中的攻击手法之一. 0x01 ...
- Java线程的并发工具类
Java线程的并发工具类. 一.fork/join 1. Fork-Join原理 在必要的情况下,将一个大任务,拆分(fork)成若干个小任务,然后再将一个个小任务的结果进行汇总(join). 适用场 ...
- java性能优化常用工具jmap、jstack
jmap:java内存映像工具 jmap用于生成堆转储快照,比较常用的option包括-heap,-histo,-dump [root@localhost script]# jmap -h Usage ...
随机推荐
- R语言爬虫:CSS方法与XPath方法对比(表格介绍)
css 选择器与 xpath 用法对比 目标 匹配节点 CSS 3 XPath 所有节点 ~ * //* 查找一级.二级.三级标题节点 <h1>,<h2>,<h3> ...
- Java基础之final和abstract关键字
final final在Java中是一个保留的关键字,可以声明成员变量.方法.类以及本地变量.一旦你将引用声明作final,你将不能改变这个引用了,编译器会检查代码,如果你试图将变量再次初始化的话,编 ...
- js闭包的理解-目前网上分析的最透彻文章
js的闭包对于大家实际上并不陌生,但是真正敢说自己完全理解的人并不多.笔者在网上看到分析闭包的文章非常多,篇幅用的非常多,但是实际上分析的并不到位,或者根本就是不正确的.我有时候都在想,写这些文章的人 ...
- BAPIを使用のODATA作成
入力: AIRLINE テーブル: FLIGHT_LIST Step 1: TCode: SEGW ⇒新規作成ボタンを押す Step 2: オブジェクト名など入力 Step 3: オブジェクト作成完了 ...
- postgresql 日期类型处理实践
---- 日期+1 select date '2018-01-14' + integer '1'; 结果: 2018-01-15 ---- 日期+1 后 转 20180101 日期字符串 select ...
- Intellij打包jar文件,“java.lang.SecurityException: Invalid signature file digest for Manifest main attrib
下面是使用Intellij 打包jar文件的步骤,之后会有运行jar文件时遇到的错误. 打包完成. ================================================== ...
- 【原创】linux命令-Axel命令 - linux多线程下载 - 费元星 - 未来星开发团队
[费元星版权Q:9715234] Axel 是 Linux 下一个不错的HTTP/FTP高速下载工具.支持多线程下载.断点续[费元星版权Q:9715234]传,且可以从多个地址或者从一个地址的多个连接 ...
- Unity AssetBundle工作流
一.创建AssetBundle 1.在资源的Inspector视图下有一个AssetBundle的UI,第一个选项表示AssetBundle名称,第二个用于设置AssetBundle Variant, ...
- PHP使用Redis消息队列
1.redis安装 参考:菜鸟教程http://www.runoob.com/redis/redis-install.html 2.安装php的redis扩展 1)phpinfo()查看php版本信息 ...
- Appium(Python)API
1.创建新的会话desired_caps = desired_caps = { 'platformName': 'Android', 'platformVersion': '7.0', 'dev ...