eclipse tomcat JNdi配置筆記

一、遇到的錯誤
1.Name 項目名 is not bound in this Context
2.Name jdbc is not bound in this Context
解決方法:<res-ref-name> 這裏寫成   jdbc/項目名   </res-ref-name>
3.Cannot create JDBC driver of class '' for connect URL 'null'class '' for connect URL 'null
檢查配置:(1)web.xml   (2)tomcat/conf/server.xml

二、具體配置

1.web.xml

<resource-ref>
<span style="white-space:pre">	</span><description>DB Connection</description> 
        <res-ref-name>DingdanManager</res-ref-name> 
        <res-type>javax.sql.DataSource</res-type> 
        <res-auth>Container</res-auth>
</resource-ref>

2.server.xml

<Context docBase="DingdanManager" path="" reloadable="true" source="org.eclipse.jst.j2ee.server:DingdanManager" >
			<Resource auth="Container" name="jdbc/DingdanManager" type="javax.sql.DataSource"/>
				<ResourceParams name="jdbc/DingdanManager">
					<parameter>
						<name>factory</name>
						<value>
							org.apache.commons.dbcp.BasicDataSourceFactory
						</value>
					</parameter>

					<parameter>
						<name>maxActive</name>
						<value>10</value>
					</parameter>

					<parameter>
						<name>maxIdle</name>
						<value>10</value>
					</parameter>

					<parameter>
						<name>maxWait</name>
						<value>10000</value>
					</parameter>

					<parameter>
						<name>driverClassName</name>
						<value>
							com.mysql.jdbc.Driver
						</value>
					</parameter>

					<parameter>
						<name>url</name>
						<value>
							jdbc:mysql://localhost/test
						</value>
					</parameter>

					<parameter>
						<name>validationQuery</name>
						<value>select 1 from dual</value>
					</parameter>

					<parameter>
						<name>testWhileIdle</name>
						<value>true</value>
					</parameter>

					<parameter>
						<name>username</name>
						<value>root</value>
					</parameter>

					<parameter>
						<name>password</name>
						<value>pwd</value>
					</parameter>
				</ResourceParams>
			</Context>

需要注意的是:Context起初是<Context docBase="study" path="" reloadable="true" source="org.eclipse.jst.j2ee.server:study"/>這樣的,最後有個/> ,我們寫Resource的時候就要去掉/ ,然後在最後補上 </Context>

3.tomcat的lib下要放相應數據庫鏈接的jar包,比如:mysql---mysql-connector-java.jar   Oracle--ojdbc14.jar

4.如果是tomcat5.0 以上的工作就結束了。如果是6.0、7.0,還需要在web項目下的META-INF下放置content.xml

<?xml version="1.0" encoding="UTF-8"?>
<Context>
	<Resource name="jdbc/DingdanManager" 
	auth="Container" 
	type="javax.sql.DataSource" 
	driverClassName="com.mysql.jdbc.Driver"  
	url="jdbc:mysql://localhost/test" 
	username="root" 
	password="root" 
	maxActive="100" 
	maxIdle="10" 
	maxWait="10000"/>
</Context>

三、各參數ss含義

name 表示指定的jndi名稱
auth 表示認證方式,一般爲Container
type 表示數據源牀型,使用標準的javax.sql.DataSource
maxActive 表示連接池當中最大的數據庫連接
maxIdle 表示最大的空閒連接數
maxWait 當池的數據庫連接已經被佔用的時候,最大等待時間
logAbandoned 表示被丟棄的數據庫連接是否做記錄,以便跟蹤
username 表示數據庫用戶名
password 表示數據庫用戶的密碼
driverClassName 表示JDBC DRIVER
url 表示數據庫URL地址
     

四、使用

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

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

public class Jndi {
	
	public synchronized static Connection createConn(){
		Connection conn = null;
		try{
			//初始化查找命名空間
		 	Context ctx = new InitialContext(); 
		 	//InitialContext ctx = new InitialContext();亦可 
		 	//找到DataSource,對名稱進行定位java:comp/env是必須加的,後面跟你的DataSource名
		 	DataSource ds = (DataSource)ctx.lookup("java:comp/env/jdbc/DingdanManager");
			conn = ds.getConnection();
		} catch (NamingException e) {
		 	System.out.println(e.getMessage());
		} catch (SQLException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
		return conn;
	}

}






發佈了19 篇原創文章 · 獲贊 1 · 訪問量 1萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章