tomcat8配置全局数据源

李刚的书《轻量级java web企业应用实战》 p33 讲了这个功能。

First, tomcat/conf/context.xml 中加如下代码

<Context>  
    <Resource name="jdbc/shopping"
	   auth="Container"
           type="javax.sql.DataSource"
           description="User database that can be updated and saved" 
           url="jdbc:mysql://localhost:3306/shopping"
           driverClassName="com.mysql.jdbc.Driver"
           username="root"
           password="" />
如果是局部的,只需要
<Context docBase="/home/tomcat/code...">
  
Second,自己项目的web.xml中</webapp>之前加如下代码,我的是ROOT下,故路径为/tomcat/webapps/ROOT/WEB-INF/web.xml

经过测试,这一步添加的东西不需要

   <resource-ref>
          <description>DB Connection</description>
          <res-ref-name>jdbc/myconnect</res-ref-name>
          <res-type>javax.sql.DataSource</res-type>
          <res-auth>Container</res-auth>
    </resource-ref> 

Third,加mysql驱动的jar包mysql-connector-java-5.1.31.jar,由于是全局数据源,只需要在tomcat/lib目录下放这个jar包即可

Fourth,hellojsp文件

<%@ page language="java" contentType="text/html;charset=utf-8" pageEncoding="utf-8"%>
<%@ page import="javax.naming.*"%>
<%@ page import="java.sql.*"%>
<%@ page import="javax.sql.*"%>
<%
	try{
		Context initContext = new InitialContext();
		Context envContext  = (Context)initContext.lookup("java:/comp/env");
		DataSource ds = (DataSource)envContext.lookup("jdbc/shopping");
		Connection conn = ds.getConnection();	
		Statement stmt = conn.createStatement();
		ResultSet rs = stmt.executeQuery("select * from mytable");
		while(rs.next())
		{
		   out.println(rs.getString(1)+"\t"+rs.getString(2)+"<br/>");
		}
		conn.close();
	}catch(Exception ex)
	{
		out.println(ex.getMessage());
	}
%>
Fifth,数据库名是shopping,表名是mutable


Sixth,这个jsp放在/tomcat/webapps/ROOT/,在浏览器中输入localhost:8080/hello.jsp即可访问

Seventh,将这个jsp放在其他目录或者其他项目目录下,都可以正常访问,只要url路径对即可




  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值