首页 > 代码库 > WebLogic使用总结(三)——WebLogic配置JNDI数据源

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 xudp18  * @version 1.0 V19  * @createTime 2015-1-4 下午03:54:3920  */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: getInitialContext49      * Description: 获得WebLogic ServerJNDI初始上下文信息50      * @author xudp        51      * @return52      * @throws Exception53      */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: getOracleConnection63      * Description: 获取Oracle数据库连接64      * @author xudp        65      * @return66      * @throws SQLException67      */68     public static Connection getOracleConnection() throws SQLException {69         return dsOracle.getConnection();70     }71 72     /**73      * MethodName: getMySQLConnection74      * Description: 获取MySQL数据库连接75      * @author xudp        76      * @return77      * @throws SQLException78      */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 xudp20  * @version 1.0 V21  * @createTime 2015-1-4 下午03:37:5322  */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使用总结(三)——WebLogic配置JNDI数据源