NoSuchMethodError on startup in Java Jersey app

2022-09-01 13:49:54

当我尝试在Tomcat上启动泽西岛应用程序时,我遇到了一个非常奇怪的错误。相同的代码适用于其他计算机。我尝试重新安装tomcat,我所有的maven依赖项,甚至Eclipse和Java本身,没有运气。我想,似乎一个糟糕的泽西岛版本正在加载中?

任何指向正确方向的指针都将不胜感激。

这是有效的 pom:http://pastebin.com/NacsWTjz

而实际的绒球:http://pastebin.com/H6sHe4ce

2015-02-13 13:43:40,870 [localhost-startStop-1] ERROR org.apache.catalina.core.ContainerBase.[Catalina].[localhost].[/middleware-server] - StandardWrapper.Throwable
java.lang.NoSuchMethodError: javax.ws.rs.core.Application.getProperties()Ljava/util/Map;
    at org.glassfish.jersey.server.ApplicationHandler.<init>(ApplicationHandler.java:304)
    at org.glassfish.jersey.server.ApplicationHandler.<init>(ApplicationHandler.java:285)
    at org.glassfish.jersey.servlet.WebComponent.<init>(WebComponent.java:311)
    at org.glassfish.jersey.servlet.ServletContainer.init(ServletContainer.java:170)
    at org.glassfish.jersey.servlet.ServletContainer.init(ServletContainer.java:358)
    at javax.servlet.GenericServlet.init(GenericServlet.java:158)
    at org.apache.catalina.core.StandardWrapper.initServlet(StandardWrapper.java:1231)
    at org.apache.catalina.core.StandardWrapper.loadServlet(StandardWrapper.java:1144)
    at org.apache.catalina.core.StandardWrapper.load(StandardWrapper.java:1031)
    at org.apache.catalina.core.StandardContext.loadOnStartup(StandardContext.java:4901)
    at org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5188)
    at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150)
    at org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1409)
    at org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1399)
    at java.util.concurrent.FutureTask.run(FutureTask.java:266)
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
    at java.lang.Thread.run(Thread.java:745)

答案 1

注意:请参阅上面的评论,以获取进一步的讨论和提示。

此错误通常意味着类路径上同时具有 JAX-RS 1 和 JAX-RS 2 jar。Jersey 2 使用 JAX-RS 2 (),但如果您有 JAX-RS 1,则每个罐子中都有一个。但是 没有方法(因此 )。javax.ws.rs-api-2.0.1.jarjsr311-api.jarjavax.ws.rs.core.Applicationjsr311-apiApplicationgetProperties()NoSuchMethodError

我得出的结论是,您需要做的就是将上述排除添加到swagger依赖项中。Jackson 2.0 提供程序(依赖于 JAX-RS 1)似乎被 2.4.1 提供程序(使用新版本)覆盖。因此,我们不需要自己添加它。当它被覆盖时,它似乎会留下.因此,如果我们排除它,没有人可以尝试使用它,这似乎是当前的问题。jsr311-api.jar

<dependency>
    <groupId>com.wordnik</groupId>
    <artifactId>swagger-core_2.10</artifactId>
    <version>1.3.11</version>
    <exclusions>
        <exclusion>
            <groupId>javax.ws.rs</groupId>
            <artifactId>jsr311-api</artifactId>
        </exclusion>
    </exclusions>
</dependency>

答案 2

我们使用的是1.9,它有一个依赖关系,它也恰好有一个类。jersey-jsonjersey-corejavax.ws.rs.core.Application

因此,我们的解决方法是从中排除球衣核心jersey-json

    <dependency>
        <groupId>com.sun.jersey</groupId>
        <artifactId>jersey-json</artifactId>
        <version>1.9</version>
        <exclusions>
            <exclusion>
                <groupId>com.sun.jersey</groupId>
                <artifactId>jersey-core</artifactId>
            </exclusion>
        </exclusions>
    </dependency>

推荐