1

在一个小型演示 JAX-RS 应用程序中,我有以下 POJO:

public class Book {
    private String title;
    private String author;
    private int year;

    // only this constructor, no default
    public Book(String title, String author, int year) {
        this.title = title;
        this.author = author;
        this.year = year;
    }

    // getters for members, no setters
    ...
}

我在 REST 操作中将此用作响应:

@GET
@Path("books")
@Produces(MediaType.APPLICATION_JSON)
public List<Book> getBooks() {
    List<Book> books = new ArrayList<>();
    // add some books via Book constructor
    ...
    return books;
}

该应用程序在 WildFly 10 上完美运行,生成图书对象的 JSON 输出。

在最近的 Payara 上部署了同样的战争,在服务器日志中给了我一个异常:

MessageBodyWriter not found for media type=application/json

在添加了默认构造函数和@XmlAccessorType(XmlAccessType.FIELD)(或设置器,出于功能设计原​​因我省略了)之后,它起作用了。

这一切让我想到了两个问题:

  • 为什么行为不同,哪个容器做一些非标准或额外的事情?
  • 是否有推荐的方法可以使用我的 Book 类等数据对象作为响应并让它自动转换为 JSON(当然还有一个额外的 http 响应代码),或者像许多示例中所示的那样,而不是手动构建 JSON 响应对象?
4

1 回答 1

4

不幸的是,Java EE 中尚未定义 Java 对象与 JSON 的映射,因此 WildFly 和 Payara Server 的行为在定义上都不是标准的。它计划由 JSON-Binding JSR 定义,它将包含在 Java EE 8 中。现在大多数实现都使用 JAX-B 进行映射,但它是为 Java 和 XML 之间的映射而设计的,并且不起作用JSON 没有问题。

默认情况下,Payara Server 使用 Moxy 映射到/从 JSON。例如,如果您将 Jackson 添加到您的应用程序并添加JacksonFeature到 JAX-RS 类中,您可以强制使用 Jackson:Force Glassfish4 使用 Jackson 而不是 Moxy

如果您希望您的应用程序始终以标准方式运行,则需要配置 JAX-RS 以使用您自己的MessageBodyWriter/Reader.

于 2017-01-18T12:17:35.887 回答