Este conteúdo não está disponível no idioma selecionado.
47.2. Returning plain Java constructs
Overview
In many cases a resource class can return a standard Java type, a JAXB object, or any object for which the application has an entity provider. In these cases the runtime determines the MIME type information using the Java class of the object being returned. The runtime also determines the appropriate HTTP return code to send to the consumer.
Returnable types
Resource methods can return
void
or any Java type for which an entity writer is provided. By default, the runtime has providers for the following:
- the Java primitives
- the
Number
representations of the Java primitives - JAXB objects
the section called “Natively supported types” lists all of the return types supported by default. the section called “Custom writers” describes how to implement a custom entity writer.
MIME types
The runtime determines the MIME type of the returned entity by first checking the resource method and resource class for a
@Produces
annotation. If it finds one, it uses the MIME type specified in the annotation. If it does not find one specified by the resource implementation, it relies on the entity providers to determine the proper MIME type.
By default the runtime assign MIME types as follows:
- Java primitives and their
Number
representations are assigned a MIME type ofapplication/octet-stream
. - JAXB objects are assigned a MIME type of
application/xml
.
Applications can use other mappings by implementing custom entity providers as described in the section called “Custom writers”.
Response codes
When resource methods return plain Java constructs, the runtime automatically sets the response's status code if the resource method completes without throwing an exception. The status code is set as follows:
204
(No Content)—the resource method's return type isvoid
204
(No Content)—the value of the returned entity isnull
200
(OK)—the value of the returned entity is notnull
If an exception is thrown before the resource method completes the return status code is set as described in Chapter 48, Handling Exceptions.