第一步:修改tomcat下conf中的server.xml文件
用文本工具打开此文件(我的tomcat版本是6.0)
找到<host>标签,向其中加入以下配置
<Context path="/jndiTest" docBase=" jndiTest "
debug="5" reloadable="true" crossContext="true">
<Resource name="jdbc/TestDB" auth="Container" type="javax.sql.DataSource"
maxActive="100" maxIdle="30" maxWait="10000"
username="sa"
password="sasa" driverClassName="com.microsoft.sqlserver.jdbc.SQLServerDriver"
url="jdbc:sqlserver://127.0.0.1:1078;databaseName=AdventureWorks"/>
</Context>
解释:path="/jndi" –你的应用
docBase="jndi" –你应用的根目录
name="jdbc/TestDB" 注册的jndi名字
<Context path="/datesource" docBase="datesource"
debug="5" reloadable="true" crossContext="true">
<Resource name="jdbc/datesource" auth="Container" type="javax.sql.DataSource"
maxActive="100" maxIdle="30" maxWait="10000"
username="sa"
password="sasa"
driverClassName="com.microsoft.sqlserver.jdbc.SQLServerDriver"
url="jdbc:sqlserver://127.0.0.1:1433;databaseName=music"/>
</Context>
第二步:修改你的应用下web.xml的文件
在结束的</web-app>上面加入下面配置
<resource-ref>
<description>DB Connection</description>
<res-ref-name>jdbc/TestDB</res-ref-name>
<res-type>javax.sql.DataSource</res-type>
<res-auth>Container</res-auth>
</resource-ref>
解释:<res-ref-name> jdbc/TestDB</res-ref-name>为在服务器中配好的jndi名,必须一样
在使用之前,不要忘了把数据库驱动包放到tomcat下面的lib目录,因为现在是由服务器给你提供数据连接而不是你的应用
第三步:在代码中使用数据源
//上下文对象
Context initContext = new InitialContext();
//获得数据源
DataSource source=(DataSource)initContext.lookup("java:comp/env/jdbc/TestDB");
//获得连接
Connection conn = source.getConnection();