9

我有一个 Java Web 应用程序。我已经设置了这个新项目并在运行 jsp 时出现以下异常,

Oct 10, 2012 3:01:49 AM org.apache.catalina.core.StandardWrapperValve invoke
SEVERE: Servlet.service() for servlet jsp threw exception
java.lang.ClassCastException: org.apache.catalina.util.DefaultAnnotationProcessor cannot be cast to org.apache.AnnotationProcessor
    at org.apache.jasper.servlet.JspServletWrapper.getServlet(JspServletWrapper.java:151)
    at org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:340)
    at org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:313)
    at org.apache.jasper.servlet.JspServlet.service(JspServlet.java:260)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:717)
    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:233)
    at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:191)
    at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:127)
    at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102)
    at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
    at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:298)
    at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:857)
    at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:588)
    at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:489)
    at java.lang.Thread.run(Thread.java:619)
Oct 10, 2012 3:01:57 AM org.apache.catalina.loader.WebappClassLoader modified
INFO:     Additional JARs have been added : 'activation-1.1.jar'
Oct 10, 2012 3:01:57 AM org.apache.catalina.core.StandardContext reload
INFO: Reloading this Context has started
Oct 10, 2012 3:01:57 AM org.apache.catalina.loader.WebappClassLoader clearReferencesJdbc
SEVERE: The web application [/AutoUpgrade] registered the JBDC driver [com.mysql.jdbc.Driver] but failed to unregister it when the web application was stopped. To prevent a memory leak, the JDBC Driver has been forcibly unregistered.
Oct 10, 2012 3:01:57 AM org.apache.catalina.loader.WebappClassLoader clearReferencesThreads
SEVERE: The web application [/AutoUpgrade] appears to have started a thread named [Timer-0] but has failed to stop it. This is very likely to create a memory leak.

我已经多次尝试清理和构建项目,获得最新的 service-api.jar,我的库非常广泛,我无法弄清楚导致此错误的任何 jar 之间是否存在任何不一致。我在 jdk 1.6 上的 Apache Tomcat 6 上运行该项目(我的项目需要在 1.6 上运行)。我试过用谷歌搜索这个异常,但没有得到任何与我的问题相关的帖子。stackoverflow 上的相关问题是关于 NullPointerException 的。

我认为问题一定出在我的库上,但我无法指出根本原因。

谢谢

4

3 回答 3

11

当您的 web 应用程序的/WEB-INF/lib. 这个不对。您应该 从那里删除所有特定于 servletcontainer 的 JAR 文件。他们根本不属于那里。它们应该已经由 servletcontainer 本身提供。应该只包含特定于 webapp 本身的库,这些/WEB-INF/lib库不是由 servletcontainer 提供的。

如果您因为尝试修复编译错误而将它们放在那里,那么请仔细阅读这个答案如何以正确的方式解决它:如何在我的 Eclipse 项目中导入 javax.servlet API?

于 2012-10-10T21:52:09.667 回答
0

如果清理你的项目没有帮助,也许你需要清除你的缓存

Netbeans 缓存位于某处...
C:\Documents and Settings\myself.netbeans\7.0\var\cache

于 2012-10-10T07:53:05.097 回答
0

从 lib 中删除以下内容。

  1. 检查具有不同版本的相同 jar
  2. 所有与 catalina 相关的罐子
  3. el-api.jar
  4. jsp-api.jar

这肯定会奏效。

于 2015-06-04T11:15:04.633 回答