48.2. 返回普通 Java 结构

概述

在很多情况下,资源类可以返回标准 Java 类型、一个 JAXB 对象或应用具有实体提供程序的任何对象。在这些情况下,运行时使用返回的对象的 Java 类决定 MIME 类型信息。该运行时还决定要发送到消费者的适当 HTTP 返回代码。

可返回的类型

资源方法可以返回 void 或提供实体写器的任何 Java 类型。默认情况下,运行时具有以下供应商:

  • Java 原语
  • Java 原语的数字表
  • JAXB 对象

“原生支持的类型”一节 列出默认支持的所有返回类型。“自定义写入器”一节 描述如何实施自定义实体作者。

MIME 类型

运行时首先检查 @Produces 注释的资源方法和资源类,从而确定返回的实体的 MIME 类型。如果找到了一个,它将使用注解中指定的 MIME 类型。如果找不到资源实现指定的,它依赖于实体提供商来确定正确的 MIME 类型。

默认情况下,运行时分配 MIME 类型,如下所示:

  • Java 原语及其数字表示被分配一个 MIME 类型的应用程序 /octet-stream
  • 为 JAXB 对象分配 MIME 类型 application/xml

应用程序可以通过实施自定义实体提供程序来使用其他映射,如 “自定义写入器”一节 所述。

响应代码

当资源方法返回普通 Java 结构时,如果资源方法完成,则运行时会自动设置响应的状态代码,而不会抛出异常。状态代码设置如下:

  • 204(无内容)- 资源类型为 void
  • 204(无内容)- 返回的实体的值是 null
  • 200(OK)- 返回的实体的值是 null

如果在资源方法完成返回状态代码前抛出异常,如 第 50 章 处理异常 所述。