我正在调查以下java.lang.VerifyError

java.lang.VerifyError: (class: be/post/ehr/wfm/application/serviceorganization/report/DisplayReportServlet, method: getMonthData signature: (IILjava/util/Collection;Ljava/util/Collection;Ljava/util/HashMap;Ljava/util/Collection;Ljava/util/Locale;Lorg/apache/struts/util/MessageRe˜̴Mt̴MÚw€mçw€mp:”MŒŒ
                at java.lang.Class.getDeclaredConstructors0(Native Method)
                at java.lang.Class.privateGetDeclaredConstructors(Class.java:2357)
                at java.lang.Class.getConstructor0(Class.java:2671)

它在部署servlet的jboss服务器启动时发生。 它是用jdk-1.5.0_11编译的,我试图用jdk-1.5.0_15重新编译它,但没有成功。也就是说,编译运行正常,但在部署时,会发生java.lang.VerifyError。

当我改变方法名,得到以下错误:

java.lang.VerifyError: (class: be/post/ehr/wfm/application/serviceorganization/report/DisplayReportServlet, method: getMD signature: (IILjava/util/Collection;Lj    ava/util/Collection;Ljava/util/HashMap;Ljava/util/Collection;Ljava/util/Locale;Lorg/apache/struts/util/MessageResources ØÅN|ØÅNÚw€mçw€mX#ÖM|XÔM
            at java.lang.Class.getDeclaredConstructors0(Native Method)
            at java.lang.Class.privateGetDeclaredConstructors(Class.java:2357
            at java.lang.Class.getConstructor0(Class.java:2671)
            at java.lang.Class.newInstance0(Class.java:321)
            at java.lang.Class.newInstance(Class.java:303)

您可以看到显示了更多的方法签名。

实际的方法签名是

  private PgasePdfTable getMonthData(int month, int year, Collection dayTypes,
                          Collection calendarDays,
                          HashMap bcSpecialDays,
                          Collection activityPeriods,
                          Locale locale, MessageResources resources) throws   Exception {

我已经试着用javap看它,它给出了方法签名,因为它应该是。

当我的其他同事检出代码、编译并部署时,他们也遇到了同样的问题。当构建服务器获取代码并将其部署到开发或测试环境(HPUX)时,会发生相同的错误。运行Ubuntu的自动测试机器在服务器启动时也显示了同样的错误。

应用程序的其余部分运行正常,只有一个servlet出了问题。 知道去哪里找会很有帮助。


当前回答

在类路径上检查同一个jar文件的多个版本。

例如,我的类路径中有opennlp-tools-1.3.0.jar和opennlp-tools-1.5.3.jar,并得到了这个错误。解决方案是删除opennlp-tools-1.3.0.jar。

其他回答

在Android上,当你试图加载一个根据Oracle的JDK编译的库时,就会发生这种情况。

这里是Ning异步HTTP客户端的问题。

在我的情况下,我的Android项目依赖于另一个为Java 7编译的Java项目。Java .lang. verifyerror在我将Java项目的编译器遵从级别更改为6.0后消失了

后来我发现这是一个Dalvik问题:https://groups.google.com/forum/?fromgroups#!主题/ android开发者/ sKsMTZ42pwE

在我的例子中,我的项目A依赖于另一个项目,比如X(A使用了X中定义的一些类),所以当我在A的构建路径中添加X作为参考项目时,我得到了这个错误。然而,当我删除X作为引用项目,并将X的jar作为库之一时,问题就解决了。

使用JRE > 6的CGLIB < 2.2可能会触发类似的错误,请参见“我应该升级到CGLIB 3.0吗?”和Spring sprr -9669上的一些评论。

当在JRE 6上一切工作正常,而仅仅切换到JRE7就会出现问题时,这一点尤其正确。

如果您正在迁移到java7或使用java7,那么通常可以看到这个错误。我遇到了上述错误,并努力找出根本原因,我建议在运行应用程序时尝试添加“-XX:-UseSplitVerifier”JVM参数。