All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.fasterxml.jackson.dataformat.xml.JacksonXmlModule Maven / Gradle / Ivy

Go to download

Data format extension for Jackson (http://jackson.codehaus.org) to offer alternative support for serializing POJOs as XML and deserializing XML as pojos. Support implemented on top of Stax API (javax.xml.stream), by implementing core Jackson Streaming API types like JsonGenerator, JsonParser and JsonFactory. Some data-binding types overridden as well (ObjectMapper sub-classed as XmlMapper).

There is a newer version: 2.18.2
Show newest version
package com.fasterxml.jackson.dataformat.xml;

import com.fasterxml.jackson.databind.AnnotationIntrospector;
import com.fasterxml.jackson.databind.module.SimpleModule;

import com.fasterxml.jackson.dataformat.xml.deser.FromXmlParser;
import com.fasterxml.jackson.dataformat.xml.deser.XmlBeanDeserializerModifier;
import com.fasterxml.jackson.dataformat.xml.ser.XmlBeanSerializerModifier;

/**
 * Module that implements most functionality needed to support producing and
 * consuming XML instead of JSON, used by {@link XmlMapper} for registering
 * handlers for XML-specific processing.
 *

* NOTE: please do NOT register this directly on {@link XmlMapper}: mapper * registers an instance (either one explicitly given in constructor, or, if none, * one it configures) and attempts to re-register is unlikely to work as * you'd expect. */ public class JacksonXmlModule extends SimpleModule implements java.io.Serializable { private static final long serialVersionUID = 1L; /** * Determination of whether indexed properties (arrays, Lists) that are not explicitly * annotated (with {@link com.fasterxml.jackson.dataformat.xml.annotation.JacksonXmlElementWrapper} * or equivalent) should default to using implicit wrapper (with same name as property) or not. * If enabled, wrapping is used by default; if false, it is not. *

* Note that JAXB annotation introspector always assumes "do not wrap by default". * Jackson annotations have different default due to backwards compatibility. * * @since 2.1 */ protected boolean _cfgDefaultUseWrapper = JacksonXmlAnnotationIntrospector.DEFAULT_USE_WRAPPER; /** * Name used for pseudo-property used for returning XML Text value (which does * not have actual element name to use). Defaults to empty String, but * may be changed for interoperability reasons: JAXB, for example, uses * "value" as name. * * @since 2.1 */ protected String _cfgNameForTextElement = FromXmlParser.DEFAULT_UNNAMED_TEXT_PROPERTY; /* /********************************************************************** /* Life-cycle: construction /********************************************************************** */ public JacksonXmlModule() { super("JacksonXmlModule", PackageVersion.VERSION); } @SuppressWarnings("deprecation") @Override public void setupModule(SetupContext context) { // Need to modify BeanDeserializer, BeanSerializer that are used context.addBeanSerializerModifier(new XmlBeanSerializerModifier()); context.addBeanDeserializerModifier(new XmlBeanDeserializerModifier(_cfgNameForTextElement)); // as well as AnnotationIntrospector context.insertAnnotationIntrospector(_constructIntrospector()); // and finally inform XmlFactory about overrides, if need be: if (_cfgNameForTextElement != FromXmlParser.DEFAULT_UNNAMED_TEXT_PROPERTY) { XmlMapper m = (XmlMapper) context.getOwner(); m.setXMLTextElementName(_cfgNameForTextElement); } // Usually this would be the first call; but here anything added will // be stuff user may has added, so do it afterwards instead. super.setupModule(context); } /* /********************************************************************** /* Life-cycle: configuration /********************************************************************** */ /** * Method that can be used to define whether {@link AnnotationIntrospector} * we register will use wrapper for indexed (List, array) properties or not, * if there are no explicit annotations. * See {@link com.fasterxml.jackson.dataformat.xml.annotation.JacksonXmlElementWrapper} * for details. *

* Note that method MUST be called before registering the module; otherwise change * will not have any effect. * * @param state Whether to enable or disable "use wrapper for non-annotated List properties" * * @since 2.1 */ public void setDefaultUseWrapper(boolean state) { _cfgDefaultUseWrapper = state; } /** * Method that can be used to define alternate "virtual name" to use * for XML CDATA segments; that is, text values. Default name is empty String * (""); but some frameworks use other names: JAXB, for example, uses * "value". *

* Note that method MUST be called before registering the module; otherwise change * will not have any effect. * * @param name Virtual name to use when exposing XML character data sections * * @since 2.1 */ public void setXMLTextElementName(String name) { _cfgNameForTextElement = name; } /* /********************************************************************** /* Internal methods /********************************************************************** */ protected AnnotationIntrospector _constructIntrospector() { return new JacksonXmlAnnotationIntrospector(_cfgDefaultUseWrapper); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy