`

javax.naming.NameNotFoundException: Name datasource is not bound in this Context

 
阅读更多

在使用JNDI获取获取数据源的时候,报了一个错误: 说数据源没有绑定到上下文中。

原因是因为:

在项目中的WEB-INF/web.xml文件中没有引用数据源:

 

添加下面一段就好了..

<!-- 数据源引用 -->
  <resource-ref>
    <description>datasource</description>
    <!--数据源名称-->
    <res-ref-name>jdbc/datasource</res-ref-name>
    <!--引用类型-->
    <res-type>javax.sql.DataSource</res-type>
    <!--容器-->
    <res-auth>Container</res-auth>
  </resource-ref>

 

错误:

javax.naming.NameNotFoundException: Name datasource is not bound in this Context
 at org.apache.naming.NamingContext.lookup(NamingContext.java:803)
 at org.apache.naming.NamingContext.lookup(NamingContext.java:145)
 at org.apache.naming.NamingContext.lookup(NamingContext.java:814)
 at org.apache.naming.NamingContext.lookup(NamingContext.java:145)
 at org.apache.naming.NamingContext.lookup(NamingContext.java:814)
 at org.apache.naming.NamingContext.lookup(NamingContext.java:145)
 at org.apache.naming.NamingContext.lookup(NamingContext.java:814)
 at org.apache.naming.NamingContext.lookup(NamingContext.java:159)
 at org.apache.naming.SelectorContext.lookup(SelectorContext.java:158)
 at javax.naming.InitialContext.lookup(InitialContext.java:392)
 at com.pack.security.filter.AuthorizationFilter.getConnection(AuthorizationFilter.java:71)
 at com.pack.security.filter.AuthorizationFilter.getPreparedStatment(AuthorizationFilter.java:84)
 at com.pack.security.filter.AuthorizationFilter.getResultSet(AuthorizationFilter.java:96)
 at com.pack.security.filter.AuthorizationFilter.getUserModelByUserID(AuthorizationFilter.java:109)
 at com.pack.security.filter.AuthorizationFilter.doFilter(AuthorizationFilter.java:47)
 at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:243)
 at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210)
 at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:224)
 at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:175)
 at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:582)
 at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:164)
 at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:100)
 at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:929)
 at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:118)
 at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:405)
 at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:279)
 at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:515)
 at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:302)
 at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:885)
 at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:907)
 at java.lang.Thread.run(Thread.java:619)
2012-1-11 10:44:39 org.apache.catalina.core.StandardWrapperValve invoke
严重: Servlet.service() for servlet [jsp] in context with path [/TomcatSecurityValidte] threw exception        

分享到:
评论
3 楼 kely39 2013-12-21  
kely39 写道
楼主,我遇到和你一样的问题,请问你解决了吗?求指示(348224249)

已经解决了
2 楼 zhou363667565 2013-12-21  
已经解决了,就是引用这段数据源就OK了。
1.<!-- 数据源引用 --> 
2.  <resource-ref> 
3.    <description>datasource</description> 
4.    <!--数据源名称--> 
5.    <res-ref-name>jdbc/datasource</res-ref-name> 
6.    <!--引用类型--> 
7.    <res-type>javax.sql.DataSource</res-type> 
8.    <!--容器--> 
9.    <res-auth>Container</res-auth> 
10.  </resource-ref>
1 楼 kely39 2013-12-15  
楼主,我遇到和你一样的问题,请问你解决了吗?求指示(348224249)

相关推荐

Global site tag (gtag.js) - Google Analytics