文档章节

在WebLogic新建针对Oracle数据库的JNDI数据源

中小宇
 中小宇
发布于 2016/11/18 14:10
字数 1238
阅读 70
收藏 0

一、在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工具类代码如下:

 

/**
 * 
 */
package me.gacl.util;

import java.sql.Connection;
import java.sql.SQLException;
import java.util.Properties;

import javax.naming.Context;
import javax.naming.InitialContext;
import javax.sql.DataSource;

/**
 * <p>ClassName: WebLogicJndiUtil<p>
 * <p>Description: 获取WebLogic服务器中的JNDI数据源工具类<p>
 * @author xudp
 * @version 1.0 V
 * @createTime 2015-1-4 下午03:54:39
 */
public class WebLogicJndiUtil {

    //初始化上下文需要用到的工厂类
    private final static String INITIAL_CONTEXT_FACTORY="weblogic.jndi.WLInitialContextFactory";
    //WebLogic服务器的访问地址
    private final static String PROVIDER_URL="t3://192.168.1.144:7001";
    //WebLogic服务器中的JNDI数据源名称
    private final static String ORACLE_JNDI_NAME="JNDI/OracleDataSource";
    private final static String MYSQL_JNDI_NAME="JNDI/MysqlDataSource";
    
    //存储从JNDI容器中取出来的数据源
    private static DataSource dsOracle = null;
    private static DataSource dsMySQL = null;
    
    static {
        try {
            //初始化WebLogic Server的JNDI上下文信息
            Context context = getInitialContext();
            //获取数据源对象
            dsOracle = (DataSource) context.lookup(ORACLE_JNDI_NAME);
            dsMySQL = (DataSource) context.lookup(MYSQL_JNDI_NAME);
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
    
    /**
     * MethodName: getInitialContext
     * Description: 获得WebLogic ServerJNDI初始上下文信息
     * @author xudp        
     * @return
     * @throws Exception
     */
    private static Context getInitialContext() throws Exception {
        Properties properties = new Properties();
        properties.put(Context.INITIAL_CONTEXT_FACTORY, INITIAL_CONTEXT_FACTORY);
        properties.put(Context.PROVIDER_URL, PROVIDER_URL);
        return new InitialContext(properties);
    }

    /**
     * MethodName: getOracleConnection
     * Description: 获取Oracle数据库连接
     * @author xudp        
     * @return
     * @throws SQLException
     */
    public static Connection getOracleConnection() throws SQLException {
        return dsOracle.getConnection();
    }

    /**
     * MethodName: getMySQLConnection
     * Description: 获取MySQL数据库连接
     * @author xudp        
     * @return
     * @throws SQLException
     */
    public static Connection getMySQLConnection() throws SQLException {
        return dsMySQL.getConnection();
    }
}

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

package me.gacl.test;

import java.io.IOException;
import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import me.gacl.util.WebLogicJndiUtil;

/**
 * <p>ClassName: JndiTestServlet<p>
 * <p>Description: <p>
 * @author xudp
 * @version 1.0 V
 * @createTime 2015-1-4 下午03:37:53
 */
public class JndiTestServlet extends HttpServlet {
   
    public void doGet(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {
        //Oracle数据库连接对象
        Connection oracleConn = null;
        //MySQL数据库连接对象
        Connection mysqlConn = null;
        Statement stmt = null;
        ResultSet rs = null;
        try {
            String sqlOracle = "SELECT * FROM LEAD_OAMS_APPLICATIONS";
            //获取数据库连接对象
            oracleConn = WebLogicJndiUtil.getOracleConnection();
            stmt = oracleConn.createStatement();
            rs = stmt.executeQuery(sqlOracle);
            while (rs.next()) {
                System.out.println(rs.getString("RESOURCEID")+"---"+rs.getString("APP_NAME"));
            }
            System.out.println("-----------------------------分割线-------------------------------------");
            
            String sqlMySQL = "SELECT * FROM LEAD_OAMS_DBSOURCES";
            //获取数据库连接对象
            mysqlConn = WebLogicJndiUtil.getMySQLConnection();
            stmt = mysqlConn.createStatement();
            rs = stmt.executeQuery(sqlMySQL);
            while (rs.next()) {
                System.out.println(rs.getString("RESOURCEID")+"---"+rs.getString("DBSOURCE_NAME"));
            }
        } catch (SQLException e) {
            e.printStackTrace();
        }finally{
            try {
                rs.close();
                stmt.close();
                oracleConn.close();
            } catch (SQLException e) {
                e.printStackTrace();
            }
        }
    }

    public void doPost(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {
        doGet(request,response);
    }
}

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

<servlet>
    <servlet-name>JndiTestServlet</servlet-name>
    <servlet-class>me.gacl.test.JndiTestServlet</servlet-class>
</servlet>

<servlet-mapping>
    <servlet-name>JndiTestServlet</servlet-name>
    <url-pattern>/servlet/JndiTestServlet</url-pattern>
</servlet-mapping>

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

  

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

  

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

  

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

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

本文转载自:http://www.cnblogs.com/xdp-gacl/p/4201094.html

中小宇
粉丝 8
博文 49
码字总数 23244
作品 0
福州
高级程序员
私信 提问
Weblogic 10.1 配置JNDI 数据源

一. JNDI连接的使用原理: 1.1 在设计器中先用JDBC连接到数据库,建立数据库连接,然后用SQL或者其他方法创建数据集,使用数据集制作好报表,然后把建立的数据库连接从JDBC连接改成JNDI连接,...

finereport
2011/12/15
809
0
centos安装weblogic,启动报错

我在虚拟机的centos上安装了weblogic,并新建的域,都成功了,但启动的时候有报错。我的weblogic版本是10.3.5 ,jdk是1.7. 哪位大神遇到过,求解答!!! JAVA Memory arguments: -Xms512m -X...

YesI_Du
2016/06/22
358
1
WebLogic 安全研究报告

作者: 图南,r00t4dm @奇安信A-TEAM 公众号: 奇安信 CERT 可能是你能找到的最详细的WebLogic安全相关中文文档 序 从我还未涉足安全领域起,就知道WebLogic的漏洞总会在安全圈内变成热点话题...

奇安信 A-Team
08/13
0
0
JTA 在Weblogic中的使用实例

在复杂的J2EE应用中,如果涉及到要在一个事务中将数据保存到多个数据库,或者在一个事务中同时要操作数据库资源和JMS资源, 为了保证数据在多个参入的数据源中的一致性,就需要用到JTA来控制事务...

晨曦之光
2012/04/25
2.1K
0
从流量侧浅谈WebLogic远程代码执行漏洞(CVE-2018-3191)

最早发到了freebuf上,和团队成员一起完成的。没注明原创,freebuf小婊子就没给钱。 一、前言 在不久前Oracle官方发布的10月重要补丁更新公告(Oracle Critical Patch Update Advisory – Oc...

303Donatello
2018/11/20
0
0

没有更多内容

加载失败,请刷新页面

加载更多

Spring Boot + Mybatis + Ehcache 二级缓存实例

二级缓存是多个SqlSession共享的,其作用域是mapper的同一个namespace,不同的sqlSession两次执行相同namespace下的sql语句且向sql中传递参数也相同即最终执行相同的sql语句,第一次执行完毕...

xiaolyuh
21分钟前
4
0
Spring源码学习(二)哎呦,按菜谱做菜与AbstractAutowireCapableBeanFactory.createBean流程差不多

记得跟老婆谈恋爱时,有一天心血来潮给老婆做饭,按照菜谱一步一步的做,结果差点把厨房烧了!!! 这事至今老婆还记得。 入口 上一篇说了,AbstractBeanFactory.getBean的主流程 ,今天来说下...

温安适
23分钟前
36
0
前端UI攻城狮 你们该抛弃jQuery了

你不再需要jQuery! Web工程师太依赖jQuery了,某种意义上说jQuery已经成了JavaScript的同义词。但是我们真的需要他么?或许我们应该反思一下什么时候才真的需要jQuery。 对我个人而言开始使...

前端老手
24分钟前
5
0
六、Java设计模式之工厂方法

工厂方法定义: 定义一个创建对象的接口,但让实现这个接口的类来决定实例化哪个类,工厂方法让类的实例化推迟到子类中进行 类型:创建型 工厂方法-使用场景: 创建对象需要大量重复的代码 ...

东风破2019
今天
6
0
win服务器管理遇到的一系列问题记录

有些小伙伴在使用iis7远程桌面管理工具的时候总是会遇到一系列的问题,下面就是为大家介绍一下服务器日常管理过程中出现的问题及我的解决办法和心得。希望能帮到大家。   拒绝服务器重新启...

1717197346
今天
6
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部