WebLogic使用总结(三)——WebLogic配置JNDI数据源
一、在WebLogic新建针对Oracle数据库的JNDI数据源
  进入weblogic管理控制台,此处是远程访问:http://192.168.1.144:7001/console

点击左侧【 域结构】→【base domain】→【服务】→【数据源】 然后点击右侧【新建】→【般数据源】,如下图所示:

填写JDBC数据源的【名称】、【jndi名称】,选择数据库类型,如选择【oracle】,下一步

选择Oracle数据库的驱动程序,如下图所示:

这里选择【Oracle’ s Driver (Thin)for Instance connections;Version:Any】,点击【下一步】按钮,进入下一个配置步骤:

这里使用默认配置即可 ,点击【下一步】按钮,进入下一个配置步骤:如下图所示:

填写数据库的连接信息:要连接的数据库,数据库的IP地址,连接数据库时使用的端口号,登录数据库时使用的用户名和密码

点击【下一步】按钮,进入下一个配置步骤:如下图所示:

连接测试结果如下:

点击【下一步】按钮,进入下一个配置步骤:如下图所示:

点击【完成】,这样WebLogic就会创建一个新的JDBC数据源,如下图所示:

到此,在WebLogic新建针对Oracle数据库的JNDI数据源就算是全部完成了。数据源创建之后,我们就可以在应用程序中使用数据源了。

二、在WebLogic新建针对MySQL数据库的JNDI数据源
  上面我们已经配置好了一个针对Oracle数据库的JNDI数据源,这里我们在新建一个针对MySQL数据库的数据源,配置步骤和上述针对Oracle数据库创建的JDBC数据源大部分是一样的,针对不一样的地方给出如下的截图说明:



  

  

到此,在WebLogic新建针对MySQL数据库的JNDI数据源就算是全部完成了。查看jndi树,可以看到JNDI树上面挂载了两个数据源,如下图所示:

三、在应用程序中使用WebLogic配置JNDI数据源
3.1、创建测试项目
  新建一个测试项目,如下图所示:

3.2、编写测试代码
  编写一个WebLogicJndiUtil工具类,用于从WebLogic的JNDI容器中取出数据源。

WebLogicJndiUtil工具类代码如下:

1 /**2  * 3  */4 package me.gacl.util;5 6 import java.sql.Connection;7 import java.sql.SQLException;8 import java.util.Properties;9
10 import javax.naming.Context;
11 import javax.naming.InitialContext;
12 import javax.sql.DataSource;
13
14 /**
15  * <p>ClassName: WebLogicJndiUtil<p>
16  * <p>Description: 获取WebLogic服务器中的JNDI数据源工具类<p>
17  * @author xudp
18  * @version 1.0 V
19  * @createTime 2015-1-4 下午03:54:39
20  */
21 public class WebLogicJndiUtil {22
23     //初始化上下文需要用到的工厂类
24     private final static String INITIAL_CONTEXT_FACTORY="weblogic.jndi.WLInitialContextFactory";
25     //WebLogic服务器的访问地址
26     private final static String PROVIDER_URL="t3://192.168.1.144:7001";
27     //WebLogic服务器中的JNDI数据源名称
28     private final static String ORACLE_JNDI_NAME="JNDI/OracleDataSource";
29     private final static String MYSQL_JNDI_NAME="JNDI/MysqlDataSource";
30
31     //存储从JNDI容器中取出来的数据源
32     private static DataSource dsOracle = null;
33     private static DataSource dsMySQL = null;
34
35     static {36         try {37             //初始化WebLogic Server的JNDI上下文信息
38             Context context = getInitialContext();
39             //获取数据源对象
40             dsOracle = (DataSource) context.lookup(ORACLE_JNDI_NAME);
41             dsMySQL = (DataSource) context.lookup(MYSQL_JNDI_NAME);
42         } catch (Exception e) {43             e.printStackTrace();
44         }
45     }
46
47     /**
48      * MethodName: getInitialContext
49      * Description: 获得WebLogic ServerJNDI初始上下文信息
50      * @author xudp
51      * @return
52      * @throws Exception
53      */
54     private static Context getInitialContext() throws Exception {55         Properties properties = new Properties();
56         properties.put(Context.INITIAL_CONTEXT_FACTORY, INITIAL_CONTEXT_FACTORY);
57         properties.put(Context.PROVIDER_URL, PROVIDER_URL);
58         return new InitialContext(properties);
59     }
60
61     /**
62      * MethodName: getOracleConnection
63      * Description: 获取Oracle数据库连接
64      * @author xudp
65      * @return
66      * @throws SQLException
67      */
68     public static Connection getOracleConnection() throws SQLException {69         return dsOracle.getConnection();
70     }
71
72     /**
73      * MethodName: getMySQLConnection
74      * Description: 获取MySQL数据库连接
75      * @author xudp
76      * @return
77      * @throws SQLException
78      */
79     public static Connection getMySQLConnection() throws SQLException {80         return dsMySQL.getConnection();
81     }
82 }

编写一个测试Servlet,JndiTestServlet的代码如下:

 1 package me.gacl.test;2 3 import java.io.IOException;4 import java.sql.Connection;5 import java.sql.ResultSet;6 import java.sql.SQLException;7 import java.sql.Statement;8 9 import javax.servlet.ServletException;
10 import javax.servlet.http.HttpServlet;
11 import javax.servlet.http.HttpServletRequest;
12 import javax.servlet.http.HttpServletResponse;
13
14 import me.gacl.util.WebLogicJndiUtil;
15
16 /**
17  * <p>ClassName: JndiTestServlet<p>
18  * <p>Description: <p>
19  * @author xudp
20  * @version 1.0 V
21  * @createTime 2015-1-4 下午03:37:53
22  */
23 public class JndiTestServlet extends HttpServlet {24
25     public void doGet(HttpServletRequest request, HttpServletResponse response)
26             throws ServletException, IOException {27         //Oracle数据库连接对象
28         Connection oracleConn = null;
29         //MySQL数据库连接对象
30         Connection mysqlConn = null;
31         Statement stmt = null;
32         ResultSet rs = null;
33         try {34             String sqlOracle = "SELECT * FROM LEAD_OAMS_APPLICATIONS";
35             //获取数据库连接对象
36             oracleConn = WebLogicJndiUtil.getOracleConnection();
37             stmt = oracleConn.createStatement();
38             rs = stmt.executeQuery(sqlOracle);
39             while (rs.next()) {40                 System.out.println(rs.getString("RESOURCEID")+"---"+rs.getString("APP_NAME"));
41             }
42             System.out.println("-----------------------------分割线-------------------------------------");
43
44             String sqlMySQL = "SELECT * FROM LEAD_OAMS_DBSOURCES";
45             //获取数据库连接对象
46             mysqlConn = WebLogicJndiUtil.getMySQLConnection();
47             stmt = mysqlConn.createStatement();
48             rs = stmt.executeQuery(sqlMySQL);
49             while (rs.next()) {50                 System.out.println(rs.getString("RESOURCEID")+"---"+rs.getString("DBSOURCE_NAME"));
51             }
52         } catch (SQLException e) {53             e.printStackTrace();
54         }finally{55             try {56                 rs.close();
57                 stmt.close();
58                 oracleConn.close();
59             } catch (SQLException e) {60                 e.printStackTrace();
61             }
62         }
63     }
64
65     public void doPost(HttpServletRequest request, HttpServletResponse response)
66             throws ServletException, IOException {67         doGet(request,response);
68     }
69 }

在Web.xml文件中注册JndiTestServlet,如下:

1 <servlet>
2     <servlet-name>JndiTestServlet</servlet-name>
3     <servlet-class>me.gacl.test.JndiTestServlet</servlet-class>
4 </servlet>
5
6 <servlet-mapping>
7     <servlet-name>JndiTestServlet</servlet-name>
8     <url-pattern>/servlet/JndiTestServlet</url-pattern>
9 </servlet-mapping>

将测试项目部署到WebLogic服务器中运行,如下图所示:

输入JndiTestServlet的访问地址:http://localhost:7001/WebLogic_Jndi_Test/servlet/JndiTestServlet进行测试,如下图所示:

访问JndiTestServlet的过程中没有出现任何错误,后台的控制台中输出了从数据库中取出来的数据,如下图所示:

这就证明了我们已经成功地从WebLogic服务器中的JNDI树中取出了JDBC数据源,再通过数据源获取到了数据库连接,执行SQL从数据库中查询出数据。

以上就是关于在WebLogic配置JNDI数据源以及如何在应用程序中使用配置好的JNDI数据源的全部内容。

原文作者:孤傲苍狼
只为成功找方法,不为失败找借口!

WebLogic 配置JNDI数据源相关推荐

  1. WebLogic配置JNDI数据源

    进入weblogic管理控制台,此处是本地访问:http://127.0.0.1:7001/console 点击左侧[ 域结构]→[base domain]→[服务]→[数据源] 然后点击右侧[新建] ...

  2. 【WebLogic使用】3.WebLogic配置jndi数据源

    一.什么是jndi数据源 JNDI是Java命名与目录接口(Java Naming and Directory Interface),在J2EE规范中是重要的规范之一. 我们平时开发web程序的时候, ...

  3. jndi weblogic mysql_WebLogic配置JNDI数据源及在项目的使用方法

    一.在WebLogic新建针对Oracle数据库的JNDI数据源 点击左侧[ 域结构]→[base domain] → [服务] → [数据源] 然后点击右侧[ 新建] → [般数据源], 如下图所示 ...

  4. jndi weblogic mysql_WebLogic配置JNDI数据源

    一.什么是jndi数据源 JNDI是Java命名与目录接口(Java Naming and Directory Interface),在J2EE规范中是重要的规范之一. 我们平时开发web程序的时候, ...

  5. log4jdbc oracle,通过weblogic配置log4jdbc数据源,在项目中使用该数据源,输出sql

    通过weblogic配置log4jdbc数据源,在项目中使用该数据源,输出sql 通过weblogic配置log4jdbc数据源,在项目中使用该数据源,输出sql 说一下配置: 服务器weblogic ...

  6. 在Tomcat配置JNDI数据源的三种方式

    转载自   在Tomcat配置JNDI数据源的三种方式 在我过去工作的过程中,开发用服务器一般都是Tomcat,数据源的配置往往都是在applicationContext.xml中配置一个dataSo ...

  7. Tomcat下使用Druid配置JNDI数据源

    转:Tomcat下使用Druid配置JNDI数据源 http://blog.csdn.net/houbin0912/article/details/52535982

  8. tomcat中配置jndi数据源以便spring获取

    [0]README 0)intro to jndi, plase visit intro to jndi: 1)本文译自 Configuring Spring MVC JdbcTemplate wit ...

  9. Tomcat配置JNDI数据源

    经过3个多小时的努力,配置JNDI数据源(主要是通过DBCP连接池)终于搞定- 还是Tomcat官方的说明好,不过全是英文的,大概还看得懂. 百度上那么花花绿绿的太多了,一个也没成功!... 本例使用 ...

最新文章

  1. NandFlash详述【转】
  2. php在没用xdebug等调试工具的情况下如何让调试内容优雅地展现出来?--php数组格式化...
  3. Android中focusable属性的妙用——底层按钮的实现
  4. java压缩----使用sun JDK压缩--中文的文件名会是乱码
  5. VHDL中的分辨函数
  6. 图像识别开源代码_灰度图像着色开源代码
  7. cron表达式 每天0点10分和30分_查找特定时间段cron任务方法
  8. 2017.8.7 GT考试 思考记录
  9. lodash源码分析之baseFindIndex中的运算符优先级
  10. 什么是数字证书?它有什么作用?
  11. ABAQUS盾构隧道开挖模型Cae文件,一环7片,含螺栓,配筋。 (此模型用的㎜单位制)
  12. 快易省智:数据中心UPS四大演进方向
  13. 怎么用Hypermesh划分球体网格
  14. 360企业版服务器修改了,360企业版安装部署方法详细攻略
  15. mysql的索引缺点_Sqlite数据库中索引的使用、索引的优缺点
  16. AI vs ML:有什么区别?
  17. python get方法列表参数_python中requests库get方法带参数请求
  18. 使用组件不渲染 Unknown custom element: <xxx> - did you register the component correctly? For recursiv
  19. 识别win10和linux的MBR,Win10下安装ElementaryOS双系统:UEFI和Legacy引导
  20. 论文阅读5 | Recent Advances in Data-Driven Wireless Communication Using Gaussian Processes: A Comprehens

热门文章

  1. ajax请求时设置cookie,如何在JavaScript中使用AJAX请求设置Cookie值?
  2. Leoplayer基于HTTP的FLV播放器
  3. 网络安全-HSRP协议
  4. 2005上半年高程考试 下午第二题
  5. 《Metasploit渗透测试手册》目录—导读
  6. android 中高级常见面试题_未完待续
  7. python找工作不好找怎么办_为何Python不好找工作?
  8. 程序员尴尬事:转角面试遇到现领导
  9. 花都狮岭计算机学校,花都狮岭学美甲学校
  10. 华为弹性云服务器ECS,自动调整搭配安全保障,畅享硬核存算能力