java - tomcat 7.0.23/jdk 1.6.x 中 java.lang.VerifyError 的解决方案?

标签 java exception tomcat verifyerror

当我在 Linux (java 1.6.x) 上将 maven 3.0.3 内置 webapp 部署到 tomcat 7.0.23 并访问在登录页面中发布我的凭据时,我收到以下错误。 pom.xml 引用 servlet 2.5、jsp 2.1 和 JSTL 1.2。

为什么我会收到此错误?我该怎么做才能避免它?

我在同一个 tomcat 实例上部署了其他 .war 文件,但在这些应用程序中从未遇到过这个问题。

我执行 http GET 的第一个 JSP(login.jsp) 没有引发错误。从第一个 JSP 到第二个 Jsp(ChLogin.jsp)的 POST 遇到了问题。

============================

根本原因

java.lang.VerifyError: (class: org/apache/jsp/ChLogin_jsp, method: _jspService signature: (Ljavax/servlet/http/HttpServletRequest;Ljavax/servlet/http/HttpServletResponse;)V) Inconsistent stack height 0 != 1
    java.lang.Class.getDeclaredConstructors0(Native Method)
    java.lang.Class.privateGetDeclaredConstructors(Class.java:2389)
    java.lang.Class.getConstructor0(Class.java:2699)
    java.lang.Class.newInstance0(Class.java:326)
    java.lang.Class.newInstance(Class.java:308)
    org.apache.jasper.servlet.JspServletWrapper.getServlet(JspServletWrapper.java:172)
    org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:369)
    org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:390)
    org.apache.jasper.servlet.JspServlet.service(JspServlet.java:334)
    javax.servlet.http.HttpServlet.service(HttpServlet.java:722)

更新 1
webapp 的 WEB-INF\lib 不包含 servlet、jsp 或 JSTL jar。它包含许多应用程序依赖项和 spring jar(我们使用 spring MVC)。

更新 2
我们不预编译 JSP。不过,这是另一天的目标。

更新 3
发现这个问题不在tomcat 7.0.12, 7.0.14, 7.0.16,而是从7.0.19开始。发布到 tomcat 用户邮件列表。得到答复,可能是 Eclipse JDT 编译器有问题。通过用tomcat 7.0.16 的JDT 编译器和LO & BEHOLD 替换tomcat 7.0.23/27 中的编译器来验证确实如此,一切都很好。我打算写信给 Eclipse JDT 编译器团队(如果有的话)并发布有关此错误的信息。

最佳答案

此错误表示 JSP 已针对特定的 Servlet/JSP/JSTL 实现进行编译,但随后 Tomcat 尝试使用 ClassPath 中可用的其他实现/版本加载已编译的类。

这可能是因为您的 WAR 包含带有 servlet、jsp 和/或 jSTL API 和/或实现的 jar 文件。由于使用的版本与 Tomcat 5.5 实现相匹配,因此它可以在那里工作,但在更新的实现中失败。

您必须设置 scope为您的 Maven POM 中的此类依赖项 provided 以从 WAR WEB-INF/lib 中排除该 jar。

要验证动态编译的代码不会加载备用依赖项,您应该使用 -verbose:class 运行 Tomcat。错误前的最新行可能有助于猜测错误所在。

2012 年 5 月 30 日更新 WEB-INF/lib 中有任何 jasperjavax.elel-api jar 吗?如果是这样,请将其/它们也删除。

您使用的 taglib 也有可能是专门为 Tomcat 5.5 Servlet 2.3 API 编译的,并且在 Tomcat 7 时会中断。

关于java - tomcat 7.0.23/jdk 1.6.x 中 java.lang.VerifyError 的解决方案?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9940721/

相关文章:

java - 无法从同一网络java访问webservice

java - 读取属性文件

java - 将一个长字符串读入内存

java - 测试输入并抛出异常的程序JAVA抛出异常时如何重新启动

c# - 尝试重新启动线程时发生 ThreadStateException

swift - 我怎样才能在 EXC_BAD_INSTRUCTION 上设置异常(exception)?

java - 应为 BEGIN_ARRAY,但在第 1 行第 2 列路径 $ 处为 STRING

java - 如何用Java11解析 "The type com.sun.crypto.provider.SunJCE is not accessible"?

linux - 如何在 Linux 中通过控制台输出启动 Tomcat?

java - 从 Java Web Start 运行 Tomcat