在使用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