java.lang.Object
org.eclipse.persistence.jaxb.MarshallerProperties
These are properties that may be set on an instance of Marshaller.  Below is
 an example of using the property mechanism to enable MOXy's JSON binding for
 an instance of Marshaller.
 
Marshaller marshaller = jaxbContext.createMarshaller(); marshaller.setProperty(MarshallerProperties.MEDIA_TYPE, "application/json");
- 
Field SummaryFieldsModifier and TypeFieldDescriptionstatic final StringProperty for setting preferred or custom validator factory.static final StringProperty for setting bean validation target groups.static final StringProperty for setting bean validation mode.static final StringProperty for disabling Bean Validation optimisations.static final StringThe Constant CHARACTER_ESCAPE_HANDLER.static final StringThe Constant INDENT_STRING.static final StringThe name of the property used to specify a value that will be prepended to all keys that are mapped to an XML attribute.static final StringDisable generation of "item" name in nested arrays in JSON.static final StringThe name of the property used to specify in the root node should be included in the message (default is true).static final StringThe Constant JSON_MARSHAL_EMPTY_COLLECTIONS.static final StringThe name of the property used to specify the character (default is '.') that separates the prefix from the key name.static final StringThe Constant JSON_REDUCE_ANY_ARRAYS.static final StringOverride default type property name for JSON as MOXy type discriminator.static final StringIf we should treat unqualified type property in JSON as MOXy type discriminator.static final StringIf there should be xsd prefix when using simple types, e.g.static final StringThe name of the property used to specify the key that will correspond to the property mapped with @XmlValue.static final StringThe Constant JSON_WRAPPER_AS_ARRAY_NAME.static final StringThe name of the property used to specify the type of binding to be performed.static final StringProperty for logging Entities content during marshalling/unmarshalling operation in MOXy.static final StringProperty for MOXy logging level.static final StringThe Constant NAMESPACE_PREFIX_MAPPER.static final String
- 
Constructor SummaryConstructors
- 
Method Summary
- 
Field Details- 
CHARACTER_ESCAPE_HANDLERThe Constant CHARACTER_ESCAPE_HANDLER. Allows for customization of character escaping when marshalling. Value should be an implementation of org.eclipse.persistence.oxm.CharacterEscapeHandler.- Since:
- 2.3.3
- See Also:
 
- 
INDENT_STRINGThe Constant INDENT_STRING. Property used to set the string used when indenting formatted marshalled documents. The default for formatted documents is " " (three spaces).- Since:
- 2.3.3
- See Also:
 
- 
JSON_ATTRIBUTE_PREFIXThe name of the property used to specify a value that will be prepended to all keys that are mapped to an XML attribute. By default there is no attribute prefix. There is no effect when media type is "application/xml". When this property is specified at the JAXBContext level all instances of Marshaller and Unmarshaller will default to this attribute prefix.- Since:
- 2.4
- See Also:
 
- 
JSON_INCLUDE_ROOTThe name of the property used to specify in the root node should be included in the message (default is true). There is no effect when media type is "application/xml". When this property is specified at the JAXBContext level all instances of Marshaller and Unmarshaller will default to this setting.- Since:
- 2.4
- See Also:
 
- 
JSON_NAMESPACE_SEPARATORThe name of the property used to specify the character (default is '.') that separates the prefix from the key name. It is only used if namespace qualification has been enabled be setting a namespace prefix mapper. When this property is specified at the JAXBContext level all instances of Marshaller and Unmarshaller will default to this setting.- Since:
- 2.4
- See Also:
 
- 
JSON_VALUE_WRAPPERThe name of the property used to specify the key that will correspond to the property mapped with @XmlValue. This key will only be used if there are other mapped properties. When this property is specified at the JAXBContext level all instances of Marshaller and Unmarshaller will default to this setting.- Since:
- 2.4
- See Also:
 
- 
MEDIA_TYPEThe name of the property used to specify the type of binding to be performed. When this property is specified at the JAXBContext level all instances of Marshaller and Unmarshaller will default to this media type. Supported values are:- MediaType.APPLICATION_XML (default)
- MediaType.APPLICATION_JSON
- "application/xml"
- "application/json"
 - Since:
- 2.4
- See Also:
 
- 
NAMESPACE_PREFIX_MAPPERThe Constant NAMESPACE_PREFIX_MAPPER. Provides a means to customize the namespace prefixes used while marshalling to XML. Used for both marshal and unmarshal when mediaType is set to "application/json". Value is either a Map of URIs to prefixes, or an implementation of org.eclipse.persistence.oxm.NamespacePrefixMapper.- Since:
- 2.3.3
- See Also:
 
- 
JSON_MARSHAL_EMPTY_COLLECTIONSThe Constant JSON_MARSHAL_EMPTY_COLLECTIONS. If true an empty or null collection will be marshalled as null or empty array, if false both will be represented as an absent node.- Since:
- 2.4
- See Also:
 
- 
JSON_REDUCE_ANY_ARRAYSThe Constant JSON_REDUCE_ANY_ARRAYS. If true arrays that have just one item in them will be reduced and marshalled as a single item and not as a collection. ie: no [ ] in the marshalled JSON Default is false so all collections (even size 1) will have the [ ] around them.- Since:
- 2.4.2
- See Also:
 
- 
JSON_USE_XSD_TYPES_WITH_PREFIXIf there should be xsd prefix when using simple types, e.g. xsd.int.- Since:
- 2.6.0
- See Also:
 
- 
JSON_TYPE_COMPATIBILITYIf we should treat unqualified type property in JSON as MOXy type discriminator.- Since:
- 2.6.0
- See Also:
 
- 
JSON_TYPE_ATTRIBUTE_NAMEOverride default type property name for JSON as MOXy type discriminator. Settings from binding file have higher priority.Example Given the following property marshaller.setProperty(MarshallerProperties.JSON_TYPE_ATTRIBUTE_NAME, "mytype"); If the property is set the JSON output will be: ... { "mytype": "phone", "contactId": 3, "number": "987654321" } ...for following object model @XmlSeeAlso({Address.class, Phone.class}) public class Contact { public int contactId; ...public class Phone extends Contact{ public String number; ...If the property is not set (default value) the JSON output will be: ... { "type": "phone", "contactId": 3, "number": "987654321" } ...Unmarshaller will use it as type discriminator to select right child class.- Since:
- 2.7.4
- See Also:
 
- 
JSON_DISABLE_NESTED_ARRAY_NAMEDisable generation of "item" name in nested arrays in JSON. Settings from binding file have higher priority.Example Given the following property marshaller.setProperty(MarshallerProperties.JSON_DISABLE_NESTED_ARRAY_NAME, "false"); If the property value is set to false (default) the JSON output will be: ... "char2dArray":[ {"item":["a","b","c","d"]}, {"item":["e","f","g","h"]} ] ...for following object model ... @XmlElement(name="char2dArray") private char[][] char2dArray; ... If the property value is set to true (default) the JSON output will be: ... "char2dArray": [ ["a","b","c","d"], ["e","f","g","h"] ] ...- Since:
- 2.7.5
- See Also:
 
- 
OBJECT_GRAPH- See Also:
 
- 
JSON_WRAPPER_AS_ARRAY_NAMEThe Constant JSON_WRAPPER_AS_ARRAY_NAME. If true the grouping element will be used as the JSON key. There is no effect when media type is "application/xml". When this property is specified at the JAXBContext level all instances of Marshaller and Unmarshaller will default to this.Example Given the following class: @XmlAccessorType(XmlAccessType.FIELD) public class Customer { @XmlElementWrapper(name="phone-numbers") @XmlElement(name="phone-number") private List<PhoneNumber> phoneNumbers; }If the property is set to false (the default) the JSON output will be: { "phone-numbers" : { "phone-number" : [ { ... }, { ... }] } }And if the property is set to true, then the JSON output will be: { "phone-numbers" : [ { ... }, { ... }] }- Since:
- 2.4.2
- See Also:
 
- 
BEAN_VALIDATION_MODEProperty for setting bean validation mode. Valid valuesBeanValidationMode.AUTO(default),BeanValidationMode.CALLBACK,BeanValidationMode.NONE.- Since:
- 2.6
- See Also:
 
- 
BEAN_VALIDATION_FACTORYProperty for setting preferred or custom validator factory. Mapped value must be instance ofValidatorFactory.- Since:
- 2.6
- See Also:
 
- 
BEAN_VALIDATION_GROUPSProperty for setting bean validation target groups. Mapped value must be of type Class[].- Since:
- 2.6
- See Also:
 
- 
BEAN_VALIDATION_NO_OPTIMISATIONProperty for disabling Bean Validation optimisations. Bean Validation in MOXy features optimisations, which are used to skip BV processes on non-constrained objects. This is to make maintenance easier and to allow for debugging in case that some object is not validated, but should be. Usage: set toBoolean.TRUEto disable optimisations, set toBoolean.FALSEto re-enable them again.- Since:
- 2.6
- See Also:
 
- 
MOXY_LOGGING_LEVELProperty for MOXy logging level. This is to make maintenance easier and to allow MOXy generate more diagnostic log messages. Allowed values are specified inLogLevelDefault value isLogLevel.INFO- Since:
- 3.0
- See Also:
 
- 
MOXY_LOG_PAYLOADProperty for logging Entities content during marshalling/unmarshalling operation in MOXy. It calls toString() method from entity. This is to make maintenance easier and to allow for debugging to check marshalled/unmarshalled content. Use it carefully. It can produce high amount of data in the log files. Usage: set toBoolean.TRUEto enable payload logging, set toBoolean.FALSEto disable it. It can be set via system property with name "eclipselink.logging.payload.moxy" too. By default it is disabled.- Since:
- 3.0
- See Also:
 
 
- 
- 
Constructor Details- 
MarshallerPropertiespublic MarshallerProperties()
 
-