2

简介: Tomcat6无法识别我在WebRoot/WEB-INF/lib中的ojdbc14.jar。我想我不需要配置任何东西,只需将 .jar 文件放在那里就可以了。

细节:

我创建了一个 Web 应用程序并将 ojdbc14.jar 放在 WEB-INF/lib 文件夹中。当我启动 Tomcat6 并访问一个 index.jsp 页面时,该页面创建了一个启动与我的 oracle 数据库的连接的对象,出现错误提示“无法加载 JDBC 驱动程序类 'oracle.jdbc.OracleDriver'”。显然Tomcat6 无法识别 web-inf/lib/ojdbc14.jar 中的“oracle.jdbc.OracleDriver”类

我做了一些研究并推测以下原因:

  1. Tomcat6 有一些不同的加载类的方法。他们在每个发布的版本中都会更改它。或者
  2. Tomcat6 有一个错误。我在 Tomcat3 中发现了一个类似的错误(请参阅此处https://bugs.eclipse.org/bugs/show_bug.cgi?id=249044)。但我怀疑这个错误可能会持续这么多版本。
  3. Tomcat6已经在自己的lib文件中包含了ojdbc14.jar的内容,再次添加到web-inf/lib会出现冲突。我不相信这一点,因为从 WEB-INF/lib 中删除 ojdbc14.jar 后,问题仍然存在。

这是我的网络应用程序结构:

  • 网络根
    • 网络信息
      • 班级
        • '用于启动连接的类'
        • ojdbc14.jar
    • 索引.jsp

错误:

org.apache.tomcat.dbcp.dbcp.SQLNestedException: Cannot load JDBC driver class 'oracle.jdbc.OracleDriver'
    at org.apache.tomcat.dbcp.dbcp.BasicDataSource.createDataSource(BasicDataSource.java:766)
    at org.apache.tomcat.dbcp.dbcp.BasicDataSource.getConnection(BasicDataSource.java:540)
    at com.demo6.DataSourceExample.getConnection(DataSourceExample.java:18)
    at org.apache.jsp.index_jsp._jspService(index_jsp.java:63)
    at org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:70)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:803)
    at org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:384)
    at org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:320)
    at org.apache.jasper.servlet.JspServlet.service(JspServlet.java:266)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:803)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
    at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:228)
    at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:175)
    at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:128)
    at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:104)
    at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
    at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:216)
    at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:844)
    at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:634)
    at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:445)
    at java.lang.Thread.run(Thread.java:619)
Caused by: java.lang.ClassNotFoundException: oracle.jdbc.OracleDriver
    at java.net.URLClassLoader$1.run(URLClassLoader.java:200)
    at java.security.AccessController.doPrivileged(Native Method)
    at java.net.URLClassLoader.findClass(URLClassLoader.java:188)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:307)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:252)
    at java.lang.ClassLoader.loadClassInternal(ClassLoader.java:320)
    at java.lang.Class.forName0(Native Method)
    at java.lang.Class.forName(Class.java:169)
    at org.apache.tomcat.dbcp.dbcp.BasicDataSource.createDataSource(BasicDataSource.java:760)
    ... 21 more
4

1 回答 1

10

堆栈跟踪告诉您已经在 Tomcat中创建了一个DataSourceas 。<Resource>在这种情况下,JDBC 驱动程序 JAR 文件确实需要放在 Tomcat 的一侧,以及管理 Tomcat 的 Tomcat DataSource,而不是您的 webapp。把它放进去Tomcat/lib,这个异常应该消失。common.loader您也可以将其放在外部文件夹中,并将其路径添加到文件中属性定义的 Tomcat 的公共类路径中/conf/catalina.properties

请注意,您不需要手动加载驱动程序。只需抓住DataSource然后从中获取Connection

于 2011-08-28T17:57:01.770 回答