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 章 处理异常 所述。