一、在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數據源的全部內容。