如何使用JNDI(Java Naming and Directory Interface)是一個應用程式介面,為開發人員提供了尋找和訪問各種命名和目錄服務的通用,統一的介面,類似JDBC都是構建在抽象層上。JNDI提供了一種統一的方式,可以用在網路上尋找和訪問服務。通過指定一個資源名稱,該名稱對應於資料庫或命名服務中的一個一個記錄,同時返回資料庫連接建立所必需的資訊。
在實際開發中,我們有時候還會使用伺服器提供給我們的資料庫連接池,比如我們希望Tomcat伺服器在啟動的時候可以協助我們建立一個資料庫連接池,那麼我們在應用程式中就不需要手動去建立資料庫連接池,直接使用Tomcat伺服器建立好的資料庫連接池即可。要想讓Tomcat伺服器再啟動的時候幫我們建立一個資料庫連接池‘,那麼需要簡單配置一下Tomcat伺服器。
配置過程如下:
(1)將資料庫驅動程式(jar包)放到Tomcat安裝目錄下的lib檔案夾中。
(2)在項目的WebContent\META-INF\目錄下手動建立一個context.xml檔案,編輯裡面的內容,最終內容如下:
<?xml version="1.0" encoding="UTF-8"?>
<Context>
<Resource name="jdbc/test" auth="Container" type="javax.sql.DataSource" maxActive="100" maxIdle="30" maxWait="10000" username="sa" password="525825GAOzhe"
driverClassName="com.microsoft.sqlserver.jdbc.SQLServerDriver"
url="jdbc:sqlserver://localhost:1433;DatabaseName=test" />
</Context>
(3)再在上面WebContent\META-INF\目錄下手動建立一個web.xml檔案,編輯裡面的內容,最終內容如下:
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://xmlns.jcp.org/xml/ns/javaee" xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd" id="WebApp_ID" version="3.1">
<resource-ref>
<description>DB Connection</description>
<res-ref-name>jdbc/test</res-ref-name>
<res-type>javax.sql.DataSource</res-type>
<res-auth>Container</res-auth>
</resource-ref>
</web-app>
(3)建立一個jsp頁面,進行資料庫的訪問測試,代碼如下:
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<%@ page import="java.sql.*, javax.sql.*,javax.naming.*,com.microsoft.*" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>資料庫連接測試</title>
</head>
<body>
<%
Connection con=null;
try{
Context ctx=new InitialContext();
DataSource ds=(DataSource)ctx.lookup("java:comp/env/jdbc/test");
con=ds.getConnection();
System.out.println("connection pool connectioned!!");
con.close();
}catch(NamingException e){
System.out.println(e.getMessage());
}catch(SQLException e){
e.printStackTrace();
}finally{
con.close();
}
%>
</body>
</html>
到此為止,資料庫的串連池就已經建立好了。