一、遇到的错误
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;
}
}