您的位置:首页 > 其它

jndi连接数据源报错解决

2011-09-20 10:25 169 查看
以前一直用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!

感觉还是第一种舒服点!不知道是否还有其它方式了!
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐