Jersey 1.x - 兼容性

时间:2017-05-23 11:30:56

标签: java jersey jersey-1.0

Jersey 1.8是否与Java 8兼容?

此外,Jersey 1.8是否与Java 8上的WildFly 8兼容?

我开发了,我现在正在维护一个REST 生成WAR的Web服务项目。

我们6个月前开始遇到一些问题 (但顺便说一句,我们现在才注意到它们)。请参阅下面的错误和截图。

在网上做了一些研究之后, 在我看来,问题与我们的项目有关 已迁移到Java 8和WildFly 8(以前它在Tomcat上运行 6与Java 6)。

所以......我认为解决方案是至少迁移到Jersey 1.9 (我们不想使用Jersey 2.x系列)。 我尝试了但是我得到了同样的错误。

所以...... Jersey 1.x与WildFly 8和Java 8完全兼容吗?

我们开始获得的错误看起来像这样。

    07:27:33,894 INFO  [com.sun.jersey.api.core.WebAppResourceConfig] (default task-7) Scanning for root resource and provider classes in the Web app resource paths:
      /WEB-INF/lib
      /WEB-INF/classes
    07:27:36,984 ERROR [io.undertow.request] (default task-7) UT005023: Exception handling request to /rpt/rpt-rest-service/report: java.lang.ArrayIndexOutOfBoundsException: 1901
            at org.objectweb.asm.ClassReader.readClass(Unknown Source) [asm-3.1.jar:3.1]
            at org.objectweb.asm.ClassReader.accept(Unknown Source) [asm-3.1.jar:3.1]
            at org.objectweb.asm.ClassReader.accept(Unknown Source) [asm-3.1.jar:3.1]
            at com.sun.jersey.spi.scanning.AnnotationScannerListener.onProcess(AnnotationScannerListener.java:133) [jersey-server-1.8-SNAPSHOT.jar:1.8-SNAPSHOT]
            at com.sun.jersey.core.spi.scanning.JarFileScanner.scan(JarFileScanner.java:97) [jersey-core-1.8-SNAPSHOT.jar:1.8-SNAPSHOT]
            at com.sun.jersey.spi.scanning.WebAppResourcesScanner$1.f(WebAppResourcesScanner.java:94) [jersey-server-1.8-SNAPSHOT.jar:1.8-SNAPSHOT]
            at com.sun.jersey.core.util.Closing.f(Closing.java:71) [jersey-core-1.8-SNAPSHOT.jar:1.8-SNAPSHOT]
            at com.sun.jersey.spi.scanning.WebAppResourcesScanner.scan(WebAppResourcesScanner.java:92) [jersey-server-1.8-SNAPSHOT.jar:1.8-SNAPSHOT]
            at com.sun.jersey.spi.scanning.WebAppResourcesScanner.scan(WebAppResourcesScanner.java:79) [jersey-server-1.8-SNAPSHOT.jar:1.8-SNAPSHOT]
            at com.sun.jersey.api.core.ScanningResourceConfig.init(ScanningResourceConfig.java:80) [jersey-server-1.8-SNAPSHOT.jar:1.8-SNAPSHOT]
            at com.sun.jersey.api.core.WebAppResourceConfig.init(WebAppResourceConfig.java:100) [jersey-server-1.8-SNAPSHOT.jar:1.8-SNAPSHOT]
            at com.sun.jersey.api.core.WebAppResourceConfig.<init>(WebAppResourceConfig.java:87) [jersey-server-1.8-SNAPSHOT.jar:1.8-SNAPSHOT]
            at com.sun.jersey.api.core.WebAppResourceConfig.<init>(WebAppResourceConfig.java:72) [jersey-server-1.8-SNAPSHOT.jar:1.8-SNAPSHOT]
            at com.sun.jersey.spi.container.servlet.WebComponent.getWebAppResourceConfig(WebComponent.java:672) [jersey-server-1.8-SNAPSHOT.jar:1.8-SNAPSHOT]
            at com.sun.jersey.spi.container.servlet.ServletContainer.getDefaultResourceConfig(ServletContainer.java:414) [jersey-server-1.8-SNAPSHOT.jar:1.8-SNAPSHOT]
            at com.sun.jersey.spi.container.servlet.ServletContainer.getDefaultResourceConfig(ServletContainer.java:581) [jersey-server-1.8-SNAPSHOT.jar:1.8-SNAPSHOT]
            at com.sun.jersey.spi.container.servlet.WebServletConfig.getDefaultResourceConfig(WebServletConfig.java:87) [jersey-server-1.8-SNAPSHOT.jar:1.8-SNAPSHOT]
            at com.sun.jersey.spi.container.servlet.WebComponent.createResourceConfig(WebComponent.java:703) [jersey-server-1.8-SNAPSHOT.jar:1.8-SNAPSHOT]
            .......

调用我的REST Web服务时在浏览器中遇到的同样异常。 请注意,此项目中没有代码或库或配置更改 (产生那个WAR)。我相信只有部署环境发生了变化。

exception

1 个答案:

答案 0 :(得分:1)

通常在问这里后一两个小时,我找到了解决方案。

解决方案是将Jersey从1.x泽西线升级到1.8以后的版本。

首先,我尝试了一种简约的方法,并升级到1.9版,但那个问题也有同样的问题。

所以我刚刚升级到1.x Jersey系列的最新版本(截至目前为1.19.3版本)。这解决了这个问题。