|
||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||
java.lang.Objectorg.jboss.resteasy.plugins.providers.AbstractEntityProvider<T>
org.jboss.resteasy.plugins.providers.jaxb.AbstractJAXBProvider<java.lang.Object>
org.jboss.resteasy.plugins.providers.jaxb.JAXBXmlTypeProvider
@Provider public class JAXBXmlTypeProvider
A JAXB entity provider that handles classes without XmlRootElement annotation. Classes which have
been generated by XJC will most likely not contain this annotation, In order for these classes to
marshalled, they must be wrapped within a JAXBElement instance. This is typically accomplished by
invoking a method on the class which serves as the XmlRegistry and is named ObjectFactory.
This provider is selected when the class is annotated with an XmlType annotation and
not an XmlRootElement annotation.
This provider simplifies this task by attempting to locate the XmlRegistry for the target class. By
default, a JAXB implementation will create a class called ObjectFactory and is located in the same package
as the target class. When this class is located, it will contain a "create" method that takes the object
instance as a parameter. For example, of the target type is called "Contact", then the ObjectFactory class
will have a method:
public JAXBElement createContact(Contact value);
| Field Summary | |
|---|---|
protected static java.lang.String |
OBJECT_FACTORY_NAME
|
| Fields inherited from class org.jboss.resteasy.plugins.providers.jaxb.AbstractJAXBProvider |
|---|
providers |
| Constructor Summary | |
|---|---|
JAXBXmlTypeProvider()
|
|
| Method Summary | |
|---|---|
static java.lang.Object |
findObjectFactory(java.lang.Class<?> type)
Attempts to locate XmlRegistry for the XML type. |
protected boolean |
isReadWritable(java.lang.Class<?> type,
java.lang.reflect.Type genericType,
java.lang.annotation.Annotation[] annotations,
MediaType mediaType)
FIXME Comment this |
java.lang.Object |
readFrom(java.lang.Class<java.lang.Object> type,
java.lang.reflect.Type genericType,
java.lang.annotation.Annotation[] annotations,
MediaType mediaType,
MultivaluedMap<java.lang.String,java.lang.String> httpHeaders,
java.io.InputStream entityStream)
Read a type from the InputStream. |
static javax.xml.bind.JAXBElement<?> |
wrapInJAXBElement(java.lang.Object t,
java.lang.Class<?> type)
If this object is managed by an XmlRegistry, this method will invoke the registry and wrap the object in a JAXBElement so that it can be marshalled. |
void |
writeTo(java.lang.Object t,
java.lang.Class<?> type,
java.lang.reflect.Type genericType,
java.lang.annotation.Annotation[] annotations,
MediaType mediaType,
MultivaluedMap<java.lang.String,java.lang.Object> httpHeaders,
java.io.OutputStream entityStream)
Write a type to an HTTP response. |
| Methods inherited from class org.jboss.resteasy.plugins.providers.jaxb.AbstractJAXBProvider |
|---|
decorateMarshaller, decorateUnmarshaller, findJAXBContext, getCharset, getMarshaller, isReadable, isWriteable, setCharset |
| Methods inherited from class org.jboss.resteasy.plugins.providers.AbstractEntityProvider |
|---|
getSize |
| Methods inherited from class java.lang.Object |
|---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
| Field Detail |
|---|
protected static final java.lang.String OBJECT_FACTORY_NAME
| Constructor Detail |
|---|
public JAXBXmlTypeProvider()
| Method Detail |
|---|
public void writeTo(java.lang.Object t,
java.lang.Class<?> type,
java.lang.reflect.Type genericType,
java.lang.annotation.Annotation[] annotations,
MediaType mediaType,
MultivaluedMap<java.lang.String,java.lang.Object> httpHeaders,
java.io.OutputStream entityStream)
throws java.io.IOException
MessageBodyWriter
writeTo in interface MessageBodyWriter<java.lang.Object>writeTo in class AbstractJAXBProvider<java.lang.Object>t - the instance to write.type - the class of object that is to be written.genericType - the type of object to be written, obtained either
by reflection of a resource method return type or by inspection
of the returned instance. GenericEntity
provides a way to specify this information at runtime.annotations - an array of the annotations on the resource
method that returns the object.mediaType - the media type of the HTTP entity.httpHeaders - a mutable map of the HTTP response headers.entityStream - the OutputStream for the HTTP entity. The
implementation should not close the output stream.
java.io.IOException - if an IO error arises
public java.lang.Object readFrom(java.lang.Class<java.lang.Object> type,
java.lang.reflect.Type genericType,
java.lang.annotation.Annotation[] annotations,
MediaType mediaType,
MultivaluedMap<java.lang.String,java.lang.String> httpHeaders,
java.io.InputStream entityStream)
throws java.io.IOException
MessageBodyReaderInputStream.
readFrom in interface MessageBodyReader<java.lang.Object>readFrom in class AbstractJAXBProvider<java.lang.Object>type - the type that is to be read from the entity stream.genericType - the type of object to be produced. E.g. if the
message body is to be converted into a method parameter, this will be
the formal type of the method parameter as returned by
Class.getGenericParameterTypes.annotations - an array of the annotations on the declaration of the
artifact that will be initialized with the produced instance. E.g. if the
message body is to be converted into a method parameter, this will be
the annotations on that parameter returned by
Class.getParameterAnnotations.mediaType - the media type of the HTTP entity.httpHeaders - the read-only HTTP headers associated with HTTP entity.entityStream - the InputStream of the HTTP entity. The
caller is responsible for ensuring that the input stream ends when the
entity has been consumed. The implementation should not close the input stream.
java.io.IOException - if an IO error arises
protected boolean isReadWritable(java.lang.Class<?> type,
java.lang.reflect.Type genericType,
java.lang.annotation.Annotation[] annotations,
MediaType mediaType)
AbstractJAXBProvider
isReadWritable in class AbstractJAXBProvider<java.lang.Object>public static java.lang.Object findObjectFactory(java.lang.Class<?> type)
XmlRegistry for the XML type. Usually, a class named ObjectFactory is located
in the same package as the type we're trying to marshall. This method simply locates this class and
instantiates it if found.
t - type -
public static javax.xml.bind.JAXBElement<?> wrapInJAXBElement(java.lang.Object t,
java.lang.Class<?> type)
t - type -
|
||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||