Jetty 9.0 embedded和RestEasy 3.0始终不会抛出任何错误

Jetty 9.0 embedded和RestEasy 3.0始终不会抛出任何错误,jetty,jax-rs,resteasy,embedded-jetty,nosuchmethoderror,Jetty,Jax Rs,Resteasy,Embedded Jetty,Nosuchmethoderror,今天,我想到了构建一个非常简单的web应用程序,它将由REST后端提供支持。因为我想要一个非常轻量级的服务器,所以我开始考虑Jetty。因为我想尝试另一种JAX-RS实现,而不是Jersey,所以我选择了RestEasy。我认为这2个应该很容易实现。我错了 我导入了基本Jetty服务器和servlet依赖项,因为我认为这是基本(仅限REST)Jetty服务器的唯一服务器要求(我尝试使用webapp依赖项;这会产生相同的错误) 示例资源: public class ExampleResources

今天,我想到了构建一个非常简单的web应用程序,它将由REST后端提供支持。因为我想要一个非常轻量级的服务器,所以我开始考虑Jetty。因为我想尝试另一种JAX-RS实现,而不是Jersey,所以我选择了RestEasy。我认为这2个应该很容易实现。我错了

我导入了基本Jetty服务器和servlet依赖项,因为我认为这是基本(仅限REST)Jetty服务器的唯一服务器要求(我尝试使用webapp依赖项;这会产生相同的错误)

示例资源:

public class ExampleResources extends Application {

    private static final ImmutableSet services = ImmutableSet.of(
            ExampleResourceImpl.class
    );

    @Override
    public Set<Class<?>> getClasses() {
        return services;
    }
}
当我转到webapge时,我得到以下跟踪:

250 [main] INFO org.eclipse.jetty.server.Server - jetty-9.0.0.RC0
911 [main] INFO org.jboss.resteasy.spi.ResteasyDeployment - Deploying javax.ws.rs.core.Application: class packages.ExampleResources
939 [main] INFO org.jboss.resteasy.spi.ResteasyDeployment - Adding class resource packages.ExampleResourceImpl from Application class packages.ExampleResources
1005 [main] INFO org.eclipse.jetty.server.handler.ContextHandler - started o.e.j.s.ServletContextHandler@702ab48{/,null,AVAILABLE}
1037 [main] INFO org.eclipse.jetty.server.ServerConnector - Started ServerConnector@465ed596{HTTP/1.1}{0.0.0.0:8080}
6315 [qtp84346444-13] WARN org.eclipse.jetty.servlet.ServletHandler - Error for /activities
java.lang.NoSuchMethodError: org.jboss.resteasy.specimpl.BuiltResponse.getHeaders()Ljavax/ws/rs/core/MultivaluedMap;
    at org.jboss.resteasy.core.ServerResponseWriter.setDefaultContentType(ServerResponseWriter.java:195)
    at org.jboss.resteasy.core.ServerResponseWriter.writeNomapResponse(ServerResponseWriter.java:46)
    at org.jboss.resteasy.core.SynchronousDispatcher.writeResponse(SynchronousDispatcher.java:411)
    at org.jboss.resteasy.core.SynchronousDispatcher.invoke(SynchronousDispatcher.java:376)
    at org.jboss.resteasy.core.SynchronousDispatcher.invoke(SynchronousDispatcher.java:179)
    at org.jboss.resteasy.plugins.server.servlet.ServletContainerDispatcher.service(ServletContainerDispatcher.java:220)
    at org.jboss.resteasy.plugins.server.servlet.HttpServletDispatcher.service(HttpServletDispatcher.java:56)
    at org.jboss.resteasy.plugins.server.servlet.HttpServletDispatcher.service(HttpServletDispatcher.java:51)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:848)
    at org.eclipse.jetty.servlet.ServletHolder.handle(ServletHolder.java:671)
    at org.eclipse.jetty.servlet.ServletHandler.doHandle(ServletHandler.java:448)
    at org.eclipse.jetty.server.handler.ContextHandler.doHandle(ContextHandler.java:1070)
    at org.eclipse.jetty.servlet.ServletHandler.doScope(ServletHandler.java:375)
    at org.eclipse.jetty.server.handler.ContextHandler.doScope(ContextHandler.java:1004)
    at org.eclipse.jetty.server.handler.ScopedHandler.handle(ScopedHandler.java:136)
    at org.eclipse.jetty.server.handler.HandlerWrapper.handle(HandlerWrapper.java:97)
    at org.eclipse.jetty.server.Server.handle(Server.java:449)
    at org.eclipse.jetty.server.HttpChannel.run(HttpChannel.java:246)
    at org.eclipse.jetty.server.HttpConnection.onFillable(HttpConnection.java:265)
    at org.eclipse.jetty.io.AbstractConnection$ReadCallback.run(AbstractConnection.java:240)
    at org.eclipse.jetty.util.thread.QueuedThreadPool.runJob(QueuedThreadPool.java:589)
    at org.eclipse.jetty.util.thread.QueuedThreadPool$3.run(QueuedThreadPool.java:520)
    at java.lang.Thread.run(Thread.java:722)

通常这意味着我忘记了依赖关系,但是我真的不知道发生了什么。

我也有同样的问题。首先,它使用JAX-RS2工作,然后它被迁移到JAX-RS3,所以我认为它与此有关。在尝试通过Maven和JBoss-deployment-structure.xml从应用程序获取JBoss use JAX-RS 3失败后,我尝试升级JBoss模块,这可以通过以下过程完成:

3.1。在JBoss AS 7中升级Resteasy Resteasy与JBoss AS 7捆绑在一起。您可能需要在AS7中升级Resteasy。 Resteasy发行版附带一个名为Resteasy-jboss-modules-3.0.1.Final.zip的zip文件。 使用JBoss AS7发行版的modules/目录解压缩此文件。这将覆盖 那里的一些现有文件

资料来源:


希望有帮助

我刚刚偶然发现了同样的问题。解决方案是显式地添加jaxrsapi作为依赖项列表中的第一个依赖项

<dependency>
    <groupId>org.jboss.resteasy</groupId>
    <artifactId>resteasy-jaxrs</artifactId>
    <version>3.0.1.Final</version>
    <scope>compile</scope>
</dependency>
<dependency>
    <groupId>org.jboss.resteasy</groupId>
    <artifactId>resteasy-jaxb-provider</artifactId>
    <version>3.0.1.Final</version>
    <scope>compile</scope>
</dependency>
<dependency>
    <groupId>org.jboss.resteasy</groupId>
    <artifactId>async-http-servlet-3.0</artifactId>
    <version>3.0.1.Final</version>
    <scope>compile</scope>
</dependency>
<dependencies>
  <!-- jaxrs-api is the very first dependency -->
  <dependency>
    <groupId>org.jboss.resteasy</groupId>
    <artifactId>jaxrs-api</artifactId>
    <version>3.0.4.Final</version>
  </dependency>
  <!-- here come the other depdendencies -->
</dependencies> 

org.jboss.resteasy
jaxrs api
3.0.4.4最终版本

Jackson使用jsr311 api,该api提供与
BuiltResponse
类相同的
Response
类。不幸的是,此
响应
不包含
getHeaders()
方法。因此,即使解决了依赖关系,也使用了错误的类。如果Jackson依赖项比Resteasy依赖项早,那么上面的异常就会出现。

我也遇到了这个问题,我花了很长时间才找到解决方法。凯文·戴是对的。问题是,我的POM中的一个依赖项间接地拉入了Jackson,并且该依赖项放在POM文件中jaxrs依赖项之前。修复方法是简单地将jaxrs依赖项移动到POM文件的顶部,以便在Jackson之前获取它。

在尝试将jax rs(使用resteasy)部署到glassfish 3.1.2.2时遇到了同样的问题。试图解决导致不一致的原因,花了几个小时,最终还是找不到——玻璃鱼的行为变得越来越奇怪


我对所有试图在gf上运行resteasy的人的建议是:停止它并使用jersey。

jetty 9.0.4.v20130625应代替RCI。我们已将jetty依赖项更改为9.0.4.v2013062版本。我总是遇到同样的异常,只是遇到了同样的问题。。在我的例子中,用
mvn运行启动jetty可以正常工作,而用
mvn运行启动jetty则不行!?添加jaxrs api确实解决了这个问题。@Wouter您的问题帮助我构建了没有Web.xml的REST服务。你应该写一个博客,因为没有像你这样清晰和简单的。我刚刚排除了jsr311 api,它现在可以工作了。这个答案对我来说很有效,但“第一依赖”实际上意味着“第一依赖”——我的问题是,Swagger和JBoss都加载了冲突的依赖项,直到我在JBoss之前列出了这个dep,我的考试不及格。最后,
是不必要的,不能单独工作。
@Path("activities")
public class ExampleResourceImpl {

    @GET
    @Produces(MediaType.TEXT_PLAIN)
    public String getAll() {
        return "Hello World";
    }
}
250 [main] INFO org.eclipse.jetty.server.Server - jetty-9.0.0.RC0
911 [main] INFO org.jboss.resteasy.spi.ResteasyDeployment - Deploying javax.ws.rs.core.Application: class packages.ExampleResources
939 [main] INFO org.jboss.resteasy.spi.ResteasyDeployment - Adding class resource packages.ExampleResourceImpl from Application class packages.ExampleResources
1005 [main] INFO org.eclipse.jetty.server.handler.ContextHandler - started o.e.j.s.ServletContextHandler@702ab48{/,null,AVAILABLE}
1037 [main] INFO org.eclipse.jetty.server.ServerConnector - Started ServerConnector@465ed596{HTTP/1.1}{0.0.0.0:8080}
6315 [qtp84346444-13] WARN org.eclipse.jetty.servlet.ServletHandler - Error for /activities
java.lang.NoSuchMethodError: org.jboss.resteasy.specimpl.BuiltResponse.getHeaders()Ljavax/ws/rs/core/MultivaluedMap;
    at org.jboss.resteasy.core.ServerResponseWriter.setDefaultContentType(ServerResponseWriter.java:195)
    at org.jboss.resteasy.core.ServerResponseWriter.writeNomapResponse(ServerResponseWriter.java:46)
    at org.jboss.resteasy.core.SynchronousDispatcher.writeResponse(SynchronousDispatcher.java:411)
    at org.jboss.resteasy.core.SynchronousDispatcher.invoke(SynchronousDispatcher.java:376)
    at org.jboss.resteasy.core.SynchronousDispatcher.invoke(SynchronousDispatcher.java:179)
    at org.jboss.resteasy.plugins.server.servlet.ServletContainerDispatcher.service(ServletContainerDispatcher.java:220)
    at org.jboss.resteasy.plugins.server.servlet.HttpServletDispatcher.service(HttpServletDispatcher.java:56)
    at org.jboss.resteasy.plugins.server.servlet.HttpServletDispatcher.service(HttpServletDispatcher.java:51)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:848)
    at org.eclipse.jetty.servlet.ServletHolder.handle(ServletHolder.java:671)
    at org.eclipse.jetty.servlet.ServletHandler.doHandle(ServletHandler.java:448)
    at org.eclipse.jetty.server.handler.ContextHandler.doHandle(ContextHandler.java:1070)
    at org.eclipse.jetty.servlet.ServletHandler.doScope(ServletHandler.java:375)
    at org.eclipse.jetty.server.handler.ContextHandler.doScope(ContextHandler.java:1004)
    at org.eclipse.jetty.server.handler.ScopedHandler.handle(ScopedHandler.java:136)
    at org.eclipse.jetty.server.handler.HandlerWrapper.handle(HandlerWrapper.java:97)
    at org.eclipse.jetty.server.Server.handle(Server.java:449)
    at org.eclipse.jetty.server.HttpChannel.run(HttpChannel.java:246)
    at org.eclipse.jetty.server.HttpConnection.onFillable(HttpConnection.java:265)
    at org.eclipse.jetty.io.AbstractConnection$ReadCallback.run(AbstractConnection.java:240)
    at org.eclipse.jetty.util.thread.QueuedThreadPool.runJob(QueuedThreadPool.java:589)
    at org.eclipse.jetty.util.thread.QueuedThreadPool$3.run(QueuedThreadPool.java:520)
    at java.lang.Thread.run(Thread.java:722)
<dependencies>
  <!-- jaxrs-api is the very first dependency -->
  <dependency>
    <groupId>org.jboss.resteasy</groupId>
    <artifactId>jaxrs-api</artifactId>
    <version>3.0.4.Final</version>
  </dependency>
  <!-- here come the other depdendencies -->
</dependencies>