Eclipse +Tomcat配置JNDI数据源

以下是具体配置的步骤:

1.首先配置Tomcat下的jndi数据源。具体存放目录apache-tomcat-7.0.59\conf\Catalina\localhost 下

osh.xml

<?xml version='1.0' encoding='utf-8'?>
<Context docBase="G:\sbwork\oshome\WebContent" reloadable="false" path="/osh">
   <Resource 
	name="jdbc/osh" auth="Container" 
	type="javax.sql.DataSource" 
        driverClassName="oracle.jdbc.driver.OracleDriver"
        url="jdbc:oracle:thin:@(DESCRIPTION=(ADDRESS_LIST =(ADDRESS=(PROTOCOL=TCP)(HOST=localhost)(PORT=1521)))(CONNECT_DATA=(SERVICE_NAME=orcl)(SERVER=DEDICATED)))" 
        validationQuery="select 0 from DUAL"
        username="olay" 
        password="123456"
        maxActive="100" 
        maxIdle="50" 
        maxWait="10000"
        removeAbandoned="true" 
        removeAbandonedTimeout="60"/> 
</Context>

(2)在tomcat的安装文件中lib目录下放入数据库驱动jar。


(3)spring的applicationContext.xml中配置datasource:

<bean id="dataSource" class="org.springframework.jndi.JndiObjectFactoryBean">
    <property name="jndiName">
        <value>java:comp/env/jdbc/osh</value>
    </property>
</bean>

注意Vlaue属性中必须加入java:comp/env,后面才是servers中的Resource 的name


(4)web.xml(这一步在eclipse项目要配上,不然找不到数据源)

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


在配置过程中,本人遇到下面问题,现在贴出来,分享一下。

同样的配置,同样的方法。Myeclipse项目启动正常,但是eclipse项目启动报错,错误入下:

org.springframework.beans.factory.BeanCreationException: Error creating bean with name ‘OSHDatasource‘ defined in ServletContext resource [/osh/config/osh-servlet.xml]: Invocation of init method failed; nested exception is javax.naming.NameNotFoundException: Name [jdbc/osh] is not bound in this Context. Unable to find [jdbc].

错误很明显是找不到jdbc/osh,导致获取不到数据源。 很郁闷的是myclipse下没问题。纠结了好久,终于找到问题所在。 Eclipse环境下在不到tomcatjndi数据源。 因此要在web.xml文件加上以下代码

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

这样就可以找到tomcat的数据源,问题解决了。

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。