Jersey 异常仅在依赖组合成单个 jar 时抛出 [英] Jersey exception only thrown when depencencies assembled into a single jar

查看:20
本文介绍了Jersey 异常仅在依赖组合成单个 jar 时抛出的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我正在编写一个嵌入 Jetty 和 Jersey 的服务器.当我从 Eclipse 执行时,一切都很好.但是,如果我使用 Maven 的 assembly:single 目标将我的服务器和所有依赖项组装到一个 jar 中,我会得到一个异常:

Sep 26, 2012 5:35:59 PM com.sun.jersey.spi.container.ContainerResponse 写严重:Java 类 com.acme.server.webservice 的消息正文编写器.exception.WebServiceFailure 和 Java 类型类 com.acme.server.webservice.exception.WebServiceFailure 和 MIME 媒体类型 application/json 不是 fo和2012 年 9 月 26 日下午 5:35:59 com.sun.jersey.spi.container.ContainerResponse 写SEVERE:注册的消息正文编写器与 MIME 媒体类型兼容是:*/* ->com.sun.jersey.server.impl.template.ViewableMessageBodyWriter17:35:59.372 [qtp184245201-22 -/] 错误 o.a.h.ReflectorServletProcessor - onRequest()javax.ws.rs.WebApplicationException: com.sun.jersey.api.MessageException: 一团糟Java 类 com.acme.server.webservice.exception.WebS 的年龄正文编写器erviceFailure 和 Java 类型类 com.acme.server.webservice.exception.WebServiceFailure,并且未找到 MIME 媒体类型 application/json在 com.sun.jersey.spi.container.ContainerResponse.write(ContainerResponse.java:285) ~[vma-server-0.0.1-SNAPSHOT-jar-with-dependencies.jar:na]在 com.sun.jersey.server.impl.application.WebApplicationImpl._handleRequest(WebApplicationImpl.java:1457) ~[server-0.0.1-SNAPSHOT-jar-with-dependencies.jar:na]

...

完整的跟踪在这里,如果它有用的话:https://gist.github.com/3790817

Maven 在创建 jar-with-dependencies 时不会抛出任何错误.

我是 Maven 和 Java 部署的新手,我真的不知道如何进行调试.

此外,虽然我需要解决这个问题,但我也很感激任何建议的变通办法,因为我需要尽快生成我的服务器的可执行演示,一个尖头老板 (tm) 可以在没有 Eclipse 的情况下执行该演示.

解决方案:

根据 Pavel 的回答,我放弃了 maven-assemly-plugin 以支持 maven-shade-plugin.这是对我有用的阴影配置:

 <插件><groupId>org.apache.maven.plugins</groupId><artifactId>maven-shade-plugin</artifactId><version>2.0</version><执行><执行><phase>包</phase><目标><目标>阴影</目标></目标><配置><变形金刚><!-- 使用转换器来处理 META-INF/services 的合并 - 参见 http://java.net/jira/browse/JERSEY-440?focusedCommentId=14822&page=com.atlassian.jira.plugin.system.issuetabpanels%3Acomment-tabpanel#action_14822 --><变压器implementation="org.apache.maven.plugins.shade.resource.ServicesResourceTransformer"/></变形金刚><过滤器><!-- 过滤以解决无效签名文件"问题-请参阅 http://stackoverflow.com/a/6743609/589215--><过滤器><神器>*:*</神器><排除><exclude>META-INF/*.SF</exclude><exclude>META-INF/*.DSA</exclude><exclude>META-INF/*.RSA</exclude></排除></过滤器></过滤器></配置></执行></执行></插件>

解决方案

您没有正确合并 Jersey jar.

Jersey 1.x 使用 META-INF/services 机制来发现它的组件和程序集:single 可能只是将所有内容复制到单个 jar 中,覆盖已经存在的文件但 META-INF/services 文件需要连接.

尝试使用 jersey-bundle (com.sun.jersey:jersey-bundle:1.14) 或修复您的程序集设置(或找到另一个插件来做得更好).

I'm writing a server that embeds Jetty w/ Jersey. When I execute from Eclipse, everything is great. However, if I assemble my server and all dependencies into a single jar using Maven's assembly:single goal, I get an exception:

Sep 26, 2012 5:35:59 PM com.sun.jersey.spi.container.ContainerResponse write
SEVERE: A message body writer for Java class com.acme.server.webservice.
exception.WebServiceFailure, and Java type class com.acme.server.webserv
ice.exception.WebServiceFailure, and MIME media type application/json was not fo
und
Sep 26, 2012 5:35:59 PM com.sun.jersey.spi.container.ContainerResponse write
SEVERE: The registered message body writers compatible with the MIME media type
are:
*/* ->
  com.sun.jersey.server.impl.template.ViewableMessageBodyWriter

17:35:59.372 [qtp184245201-22 - /] ERROR o.a.h.ReflectorServletProcessor - onReq
uest()
javax.ws.rs.WebApplicationException: com.sun.jersey.api.MessageException: A mess
age body writer for Java class com.acme.server.webservice.exception.WebS
erviceFailure, and Java type class com.acme.server.webservice.exception.
WebServiceFailure, and MIME media type application/json was not found
        at com.sun.jersey.spi.container.ContainerResponse.write(ContainerRespons
e.java:285) ~[vma-server-0.0.1-SNAPSHOT-jar-with-dependencies.jar:na]
        at com.sun.jersey.server.impl.application.WebApplicationImpl._handleRequ
est(WebApplicationImpl.java:1457) ~[server-0.0.1-SNAPSHOT-jar-with-dependenc
ies.jar:na]

...

The full trace is here, if it's useful: https://gist.github.com/3790817

Maven throws no errors while creating the jar-with-dependencies.

I'm a novice with Maven and deployment of Java, and I'm really not sure how to proceed with debugging.

Also, while I need to solve this issue I'd also appreciate any suggested work-arounds as I need to produce an executable demo of my server ASAP that a Pointy-Haired Boss (tm) can execute without Eclipse.

Solution:

Based on Pavel's answer, I dropped the maven-assemly-plugin in favor of maven-shade-plugin. Here's the shade configuration that worked for me:

        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-shade-plugin</artifactId>
            <version>2.0</version>
            <executions>
                <execution>
                    <phase>package</phase>
                    <goals>
                        <goal>shade</goal>
                    </goals>
                    <configuration>
                        <transformers>
                        <!--  use transformer to handle merge of META-INF/services - see http://java.net/jira/browse/JERSEY-440?focusedCommentId=14822&page=com.atlassian.jira.plugin.system.issuetabpanels%3Acomment-tabpanel#action_14822 -->
                            <transformer
                                implementation="org.apache.maven.plugins.shade.resource.ServicesResourceTransformer" />
                        </transformers> 
                        <filters>
                            <!--  filter to address "Invalid signature file" issue - see http://stackoverflow.com/a/6743609/589215-->
                            <filter>
                                <artifact>*:*</artifact>
                                <excludes>
                                    <exclude>META-INF/*.SF</exclude>
                                    <exclude>META-INF/*.DSA</exclude>
                                    <exclude>META-INF/*.RSA</exclude>
                                </excludes>
                            </filter>
                        </filters>
                    </configuration>
                </execution>
            </executions>
        </plugin>

解决方案

You are not merging Jersey jars correctly.

Jersey 1.x uses META-INF/services mechanism to discover its components and assembly:single probably just copies everything into single jar, overriding already present files BUT META-INF/services file(s) needs to be CONCATENATED.

Try using jersey-bundle (com.sun.jersey:jersey-bundle:1.14) or fix your assembly settings (or find another plugin to do it better).

这篇关于Jersey 异常仅在依赖组合成单个 jar 时抛出的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆