Class JacksonJaxbSmileProvider

  • All Implemented Interfaces:
    com.fasterxml.jackson.core.Versioned, javax.ws.rs.ext.MessageBodyReader<java.lang.Object>, javax.ws.rs.ext.MessageBodyWriter<java.lang.Object>

    @Provider
    @Consumes("*/*")
    @Produces("*/*")
    public class JacksonJaxbSmileProvider
    extends JacksonSmileProvider
    JSON content type provider automatically configured to use both Jackson and JAXB annotations (in that order of priority). Otherwise functionally same as JacksonSmileProvider.

    Typical usage pattern is to just instantiate instance of this provider for JAX-RS and use as is: this will use both Jackson and JAXB annotations (with Jackson annotations having priority).

    Note: class annotations are duplicated from super class, since it is not clear whether JAX-RS implementations are required to check settings of super-classes. It is important to keep annotations in sync if changed.

    • Field Detail

      • DEFAULT_ANNOTATIONS

        public static final Annotations[] DEFAULT_ANNOTATIONS
        Default annotation sets to use, if not explicitly defined during construction: use Jackson annotations if found; if not, use JAXB annotations as fallback.
    • Constructor Detail

      • JacksonJaxbSmileProvider

        public JacksonJaxbSmileProvider()
        Default constructor, usually used when provider is automatically configured to be used with JAX-RS implementation.
      • JacksonJaxbSmileProvider

        public JacksonJaxbSmileProvider​(Annotations... annotationsToUse)
        Parameters:
        annotationsToUse - Annotation set(s) to use for configuring data binding
      • JacksonJaxbSmileProvider

        public JacksonJaxbSmileProvider​(com.fasterxml.jackson.databind.ObjectMapper mapper,
                                        Annotations[] annotationsToUse)
        Constructor to use when a custom mapper (usually components like serializer/deserializer factories that have been configured) is to be used.