jtree mysql_关于数据库连接池配置引发的各种凌乱Cannot create JDBC driver of class '' for connect URL 'null’...

3..xml文件配置基本完成,然后是编写测试代码测试数据库连接池(主要连接代码如下):

Context cxt = new

InitialContext();

DataSource ds

=(DataSource)cxt.lookup("java:/comp/env/jdbc/TestDB");

conn = ds.getConnection();

二.配置项目tomcat虚拟路径:

1.发布项目运行可以有两种路径,一种是直接在tomcat目录下webapps下建立项目文件夹(如:myProject),然后在myProject下创建WEB-INF文件夹和*.jsp文件,在WEB-INF下创建classes文件夹(放java编译后的class文件)、lib文件夹(放jar包文件)、web.xml文件(配置同上),完成代码后可直接在浏览器输入http://localhost:8080/myProject/index.jsp

测试效果。

PS:此方法需手动创建相关文件夹和配置,还要把通过编译后的.class文件复制到classes文件夹中,步骤繁琐却不容易出错。

2.虚拟路径设置:不想把项目放在webapps目录下,这时需设置虚拟路径。网络上对于虚拟路径的设置有很多方法,基本上是对apache-tomcat-7.0.29\conf下的context.xml和server.xml两个文件,在

path=""

docBase="">

中设置path和docBase。但这种方法对于我的项目路径却不管用,所以我在eclipse建立在其他路径下的项目运行总是出错。本人在这问题上纠结了很久,发现是虚拟路径配置问题,根据网上的方法配置了N遍都还是出现这个Exception。具体异常如下:

org.apache.tomcat.dbcp.dbcp.SQLNestedException: Cannot

create JDBC driver of class '' for connect URL

'null'

at

org.apache.tomcat.dbcp.dbcp.BasicDataSource.createConnectionFactory(BasicDataSource.java:1452)

at

org.apache.tomcat.dbcp.dbcp.BasicDataSource.createDataSource(BasicDataSource.java:1371)

at

org.apache.tomcat.dbcp.dbcp.BasicDataSource.getConnection(BasicDataSource.java:1044)

at

mysql.database.DBConnect.init(DBConnect.java:21)

at

mysql.database.DBConnect.(DBConnect.java:43)

at

jsp.test.BookBean.addBook(BookBean.java:59)

at

jsp.test.AddBookServlet.service(AddBookServlet.java:41)

at

javax.servlet.http.HttpServlet.service(HttpServlet.java:722)

at

org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:305)

at

org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210)

at

org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:225)

at

org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:123)

at

org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:472)

at

org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:168)

at

org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:98)

at

org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:927)

at

org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:118)

at

org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:407)

at

org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1001)

at

org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:585)

at

org.apache.tomcat.util.net.AprEndpoint$SocketProcessor.run(AprEndpoint.java:1770)

at

java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1110)

at

java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:603)

at

java.lang.Thread.run(Thread.java:722)

Caused by:

java.lang.NullPointerException

at

sun.jdbc.odbc.JdbcOdbcDriver.getProtocol(JdbcOdbcDriver.java:524)

at

sun.jdbc.odbc.JdbcOdbcDriver.knownURL(JdbcOdbcDriver.java:493)

at

sun.jdbc.odbc.JdbcOdbcDriver.acceptsURL(JdbcOdbcDriver.java:307)

at

java.sql.DriverManager.getDriver(DriverManager.java:273)

at

org.apache.tomcat.dbcp.dbcp.BasicDataSource.createConnectionFactory(BasicDataSource.java:1437)

... 23 more

java.lang.NullPointerException

at

mysql.database.DBConnect.prepareStatement(DBConnect.java:252)

at

mysql.database.DBConnect.(DBConnect.java:44)

at

jsp.test.BookBean.addBook(BookBean.java:59)

at

jsp.test.AddBookServlet.service(AddBookServlet.java:41)

at

javax.servlet.http.HttpServlet.service(HttpServlet.java:722)

at

org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:305)

at

org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210)

at

org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:225)

at

org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:123)

at

org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:472)

at

org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:168)

at

org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:98)

at

org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:927)

at

org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:118)

at

org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:407)

at

org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1001)

at

org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:585)

at

org.apache.tomcat.util.net.AprEndpoint$SocketProcessor.run(AprEndpoint.java:1770)

at

java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1110)

at

java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:603)

at

java.lang.Thread.run(Thread.java:722)

解决这个异常的方法是:在eclipse中配置项目发布路径,具体如下:在eclipse下部的Servers窗口中多击Tomcat v6.0

Server at localhost,找到图中所示,将Server Locations选为第二项Use

Tomcat……

Server path:为tomcat所在目录

Deploy path:设为webapps

a4c26d1e5885305701be709a3d33442f.png

上图中Server

Locations显示为灰色,不能直接设置,因此必须新建一个Tomcatv6.0(2) Server at

localhost才能设置以上参数。具体方法是在下部Server窗口中右键点击Tomcatv6.0

Server at localhost ——new——Server(设置完成如下,这时使用新建的tomcat

server就能够正常运行项目了!!)

a4c26d1e5885305701be709a3d33442f.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值