jndi连接数据源报错解决

以前一直用MyEclipse,以后要慢慢学会用eclipse。最开始用的就是myeclipse,直到最近感觉后者更容易让自己了解项目的结构,不多说了,讲问题了!

昨天新检出了一个项目,了解后发现数据库连接方式是jndi建的数据源。没多想先启动了,报错如下:

严重: Context initialization failed
org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'dataSource' defined in ServletContext resource [/WEB-INF/classes/applicationContext.xml]: Initialization of bean failed; nested exception is javax.naming.NameNotFoundException: Name jdbc is not bound in this Context
javax.naming.NameNotFoundException: Name jdbc is not bound in this Context
                        at org.apache.naming.NamingContext.lookup(NamingContext.java:770)

肯定是数据源没找到没连接上了,网上找了很多,大体上说的配置方式是给 /tomcat/conf/server.xml中加数据源(两种方式:方式一,server.xml中项目的context中配;方式二,GlobalNamingResources中配,我两者都试过了),同时给自己的项目web.xml中加

<resource-ref>
  <res-auth>Container</res-auth>
  <res-ref-name>jndi/jdbc</res-ref-name>
  <res-type>javax.sql.DataSource</res-type>
 </resource-ref>

后来一直就报下面的错误:

org.apache.tomcat.dbcp.dbcp.SQLNestedException: Cannot create JDBC driver of class '' for connect URL 'null'

今天来到公司,启动server前publish了一次,就莫名的ok了(最后是搞明白了,因为从web.xml中的配置找数据源时没找到故而报此错,还是说明数据源位置不对)。再试试把web.xml中的那段去了,依然可以!我的理解是配置修改后没有部署到server的问题!

检查方式:看D:\workspace\.metadata\.plugins\org.eclipse.wst.server.core\tmp1\conf中的server.xml是否改过来了,记得把数据源配置在context中!

看来eclipse还是不熟悉惹的祸!

总结:

使用方式一:

只需在tomcat 的server.xml中的项目对应Context中添加数据源即可!若还在web.xml中加resource-ref定会报SQLNestedException的错

使用方式二:

GlobalNamingResources中加了数据源后在在context.xml中加一个 <ResourceLink name="jdbc/zhaopin" global="jdbc/zhaopin" type="javax.sql.DataSource"/>

是将此数据源加进服务的上下文。

其中要在项目web.xml中加resource-ref网上的说法是Tomcat4.x之前的版本是需要的,5.x后就不再需要了。

使用方式三:

后来发现的,就是在数据源加在server.xml所在目录的context.xml中,同时给项目的web.xml中加resource-ref!

感觉还是第一种舒服点!不知道是否还有其它方式了!

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值