java - REST JAX-RS javax.ws.rs.ProcessingException :

标签 java rest jboss jersey-2.0 jersey-client

每当我的 REST 客户端代码使用以下代码调用 REST 服务时,我都会遇到异常: 代码:

public void putWatcher(Watcher watcher)
    {
        System.out.println("In REST Client putWatcher.***********");

        target = target.path(RESOURCE_WATCHERS).path(watcher.getWatcheruri());
        System.out.println(target.getUri());
        Invocation.Builder builder = target.request();
        builder.put(Entity.json(watcher));
//      Response response = target.request().put(Entity.json(watcher));
        System.out.println("Returned from REST Call");
    }

异常:

: javax.ws.rs.ProcessingException: javax.ws.rs.core.Response$Status$Family.familyOf(I)Ljavax/ws/rs/core/Response$Status$Family;
    at org.glassfish.jersey.client.ClientRuntime.invoke(ClientRuntime.java:255)
    at org.glassfish.jersey.client.JerseyInvocation$1.call(JerseyInvocation.java:667)
    at org.glassfish.jersey.client.JerseyInvocation$1.call(JerseyInvocation.java:664)
    at org.glassfish.jersey.internal.Errors.process(Errors.java:315)
    at org.glassfish.jersey.internal.Errors.process(Errors.java:297)
    at org.glassfish.jersey.internal.Errors.process(Errors.java:228)
    at org.glassfish.jersey.process.internal.RequestScope.runInScope(RequestScope.java:424)
    at org.glassfish.jersey.client.JerseyInvocation.invoke(JerseyInvocation.java:664)
    at org.glassfish.jersey.client.JerseyInvocation$Builder.method(JerseyInvocation.java:424)
    at org.glassfish.jersey.client.JerseyInvocation$Builder.put(JerseyInvocation.java:318)

Caused by: java.lang.NoSuchMethodError: javax.ws.rs.core.Response$Status$Family.familyOf(I)Ljavax/ws/rs/core/Response$Status$Family;
    at org.glassfish.jersey.message.internal.Statuses$StatusImpl.<init>(Statuses.java:63)
    at org.glassfish.jersey.message.internal.Statuses$StatusImpl.<init>(Statuses.java:54)
    at org.glassfish.jersey.message.internal.Statuses.from(Statuses.java:93)
    at org.glassfish.jersey.client.HttpUrlConnector._apply(HttpUrlConnector.java:323)
    at org.glassfish.jersey.client.HttpUrlConnector.apply(HttpUrlConnector.java:227)
    at org.glassfish.jersey.client.ClientRuntime.invoke(ClientRuntime.java:246)
    ... 29 more

我的REST 服务部署在 Tomcat 8 服务器上,客户端代码部署在 JBoss 7.2 上。 客户端应用程序是 SIP-Servlets 应用程序,它还捆绑了 REST 客户端。

当我将客户端作为独立的 Java 应用程序进行测试时,它可以正常工作,但是当部署在 JBoss 上时,它会出现错误。 我的 POM 文件是:

<dependency>
    <groupId>junit</groupId>
    <artifactId>junit</artifactId>
    <version>3.8.1</version>
    <scope>test</scope>
</dependency>
<!-- logging dependency -->
<dependency>
    <groupId>log4j</groupId>
    <artifactId>log4j</artifactId>
    <version>1.2.14</version>
    <scope>provided</scope>
</dependency>
<dependency>
    <groupId>commons-logging</groupId>
    <artifactId>commons-logging-api</artifactId>
    <version>1.0.4</version>
    <scope>provided</scope>
</dependency>
<!-- web j2ee dependencies -->
<dependency>
    <groupId>javax.servlet</groupId>
    <artifactId>servlet-api</artifactId>
    <version>2.5</version>
    <scope>provided</scope>
</dependency>
<!-- sip dependencies -->
<dependency>
    <groupId>org.mobicents.servlet.sip</groupId>
    <artifactId>sip-servlets-spec</artifactId>
    <version>1.7.0.FINAL</version>
    <scope>provided</scope>
</dependency>
<dependency>
    <groupId>org.glassfish.jersey.core</groupId>
    <artifactId>jersey-client</artifactId>
    <version>2.13</version>
</dependency>
<dependency>
    <groupId>org.glassfish.jersey.core</groupId>
    <artifactId>jersey-common</artifactId>
    <version>2.13</version>
</dependency>
<dependency>
    <groupId>org.codehaus.jackson</groupId>
    <artifactId>jackson-mapper-asl</artifactId>
    <version>1.9.13</version>
</dependency>
<dependency>
    <groupId>org.glassfish.jersey.media</groupId>
    <artifactId>jersey-media-json-jackson</artifactId>
    <version>2.13</version>
</dependency>

我也尝试按照此链接 https://github.com/gondor/openstack4j/issues/30 上的建议进行操作 它说要从 JBOSS 配置 standalone.xml 中禁用 JAX-RS。我在启动服务器时使用 standalone-sip.xml,所以我只修改了它。删除了这两行:

<subsystem xmlns="urn:jboss:domain:jaxrs:1.0"/>
<extension module="org.jboss.as.jaxrs"/>

这也行不通。我不知道如何禁用,只是搜索 JAX-RS 并删除了我找到的那些行。

在一篇 SO 帖子中,有人建议使用 javax.ws.rs.core.Response respone 而不是 Response response 也尝试过但没有成功。

还有一个信息:REST 调用本身是成功的,我可以在 tomcat 服务器上看到这一点。

请建议还可以做什么。

谢谢

最佳答案

我最近遇到了这个问题。它是由提供 javax.ws.rs.core 旧实现的库引起的。我按如下方式修复了它:

    <dependency>
        <groupId>org.apache.axis2</groupId>
        <artifactId>axis2-jaxws</artifactId>
        <version>1.6.2</version>
        <scope>runtime</scope>
        <exclusions>
            <!-- Causes java.lang.NoSuchMethodError: javax.ws.rs.core.Response$Status$Family.familyOf(I)Ljavax/ws/rs/core/Response$Status$Family; -->
            <exclusion>
                <groupId>javax.ws.rs</groupId>
                <artifactId>jsr311-api</artifactId>
            </exclusion>
        </exclusions>
    </dependency>

关于java - REST JAX-RS javax.ws.rs.ProcessingException :,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27312491/

相关文章:

java - 使用 org.json.JSONObject 解析 JSON 中的转义字符;

java - 休息服务调用未触发处理程序

JBossWS 中的 Spring 配置

jboss - 事件锁定未按预期工作

java - 具有自己的对象的组合框

java - AudioStream找不到文件Java

java - Android 上的实时蓝牙 SPP 数据流只能工作 5 秒

java - RestTemplate.exchange() DELETE 删除请求正文

java - 使用 REST 请求表中记录数的最佳方法

Java Base64 : Apache Commons vs. JBoss