Class JacksonJsonMessageConverter
- All Implemented Interfaces:
Aware, BeanClassLoaderAware, MessageConverter, SmartMessageConverter
Maps an object to a BytesMessage
, or to a TextMessage
if the
targetType
is set to MessageType.TEXT
.
Converts from a TextMessage
or BytesMessage
to an object.
- Since:
- 7.0
- Author:
- Sebastien Deleuze
-
Field Summary
FieldsModifier and TypeFieldDescriptionstatic final String
The default encoding used for writing to text messages: UTF-8. -
Constructor Summary
ConstructorsConstructorDescriptionConstruct a new instance with aJsonMapper
customized with theJacksonModule
s found byMapperBuilder.findModules(ClassLoader)
.JacksonJsonMessageConverter
(tools.jackson.databind.json.JsonMapper mapper) Construct a new instance with the providedJsonMapper
.JacksonJsonMessageConverter
(tools.jackson.databind.json.JsonMapper.Builder builder) Construct a new instance with the providedJsonMapper.Builder
customized with theJacksonModule
s found byMapperBuilder.findModules(ClassLoader)
. -
Method Summary
Modifier and TypeMethodDescriptionprotected Object
convertFromBytesMessage
(jakarta.jms.BytesMessage message, tools.jackson.databind.JavaType targetJavaType) Convert a BytesMessage to a Java Object with the specified type.protected Object
convertFromMessage
(jakarta.jms.Message message, tools.jackson.databind.JavaType targetJavaType) Template method that allows for custom message mapping.protected Object
convertFromTextMessage
(jakarta.jms.TextMessage message, tools.jackson.databind.JavaType targetJavaType) Convert a TextMessage to a Java Object with the specified type.fromMessage
(jakarta.jms.Message message) Convert from a JMS Message to a Java object.protected tools.jackson.databind.JavaType
getJavaTypeForMessage
(jakarta.jms.Message message) Determine a Jackson JavaType for the given JMS Message, typically parsing a type id message property.getSerializationView
(@Nullable Object conversionHint) Determine a Jackson serialization view based on the given conversion hint.protected jakarta.jms.BytesMessage
mapToBytesMessage
(Object object, jakarta.jms.Session session, tools.jackson.databind.ObjectWriter objectWriter) Map the given object to aBytesMessage
.protected jakarta.jms.Message
mapToMessage
(Object object, jakarta.jms.Session session, tools.jackson.databind.ObjectWriter objectWriter, MessageType targetType) Template method that allows for custom message mapping.protected jakarta.jms.TextMessage
mapToTextMessage
(Object object, jakarta.jms.Session session, tools.jackson.databind.ObjectWriter objectWriter) Map the given object to aTextMessage
.void
setBeanClassLoader
(ClassLoader classLoader) Callback that supplies the beanclass loader
to a bean instance.void
setEncoding
(String encoding) Specify the encoding to use when converting to and from text-based message body content.void
setEncodingPropertyName
(String encodingPropertyName) Specify the name of the JMS message property that carries the encoding from bytes to String and back is BytesMessage is used during the conversion process.void
setTargetType
(MessageType targetType) void
setTypeIdMappings
(Map<String, Class<?>> typeIdMappings) Specify mappings from type ids to Java classes, if desired.protected void
setTypeIdOnMessage
(Object object, jakarta.jms.Message message) Set a type id for the given payload object on the given JMS Message.void
setTypeIdPropertyName
(String typeIdPropertyName) Specify the name of the JMS message property that carries the type id for the contained object: either a mapped id value or a raw Java class name.jakarta.jms.Message
Convert a Java object to a JMS Message using the supplied session to create the message object.jakarta.jms.Message
Convert a Java object to a JMS Message using the specified json view and the supplied session to create the message object.jakarta.jms.Message
A variant ofMessageConverter.toMessage(Object, Session)
which takes an extra conversion context as an argument, allowing to take, for example, annotations on a payload parameter into account.protected jakarta.jms.Message
toMessage
(Object object, jakarta.jms.Session session, tools.jackson.databind.ObjectWriter objectWriter)
-
Field Details
-
DEFAULT_ENCODING
The default encoding used for writing to text messages: UTF-8.- See Also:
-
-
Constructor Details
-
JacksonJsonMessageConverter
public JacksonJsonMessageConverter()Construct a new instance with aJsonMapper
customized with theJacksonModule
s found byMapperBuilder.findModules(ClassLoader)
. -
JacksonJsonMessageConverter
public JacksonJsonMessageConverter(tools.jackson.databind.json.JsonMapper.Builder builder) Construct a new instance with the providedJsonMapper.Builder
customized with theJacksonModule
s found byMapperBuilder.findModules(ClassLoader)
.- See Also:
-
JacksonJsonMessageConverter
public JacksonJsonMessageConverter(tools.jackson.databind.json.JsonMapper mapper) Construct a new instance with the providedJsonMapper
.- See Also:
-
-
Method Details
-
setTargetType
Specify whethertoMessage(Object, Session)
should marshal to aBytesMessage
or aTextMessage
.The default is
MessageType.BYTES
, i.e. this converter marshals to aBytesMessage
. Note that the default version of this converter supportsMessageType.BYTES
andMessageType.TEXT
only.- See Also:
-
setEncoding
Specify the encoding to use when converting to and from text-based message body content. The default encoding will be "UTF-8".When reading from a text-based message, an encoding may have been suggested through a special JMS property which will then be preferred over the encoding set on this MessageConverter instance.
- See Also:
-
setEncodingPropertyName
Specify the name of the JMS message property that carries the encoding from bytes to String and back is BytesMessage is used during the conversion process.Default is none. Setting this property is optional; if not set, UTF-8 will be used for decoding any incoming bytes message.
- See Also:
-
setTypeIdPropertyName
Specify the name of the JMS message property that carries the type id for the contained object: either a mapped id value or a raw Java class name.Default is none. NOTE: This property needs to be set in order to allow for converting from an incoming message to a Java object.
- See Also:
-
setTypeIdMappings
Specify mappings from type ids to Java classes, if desired. This allows for synthetic ids in the type id message property, instead of transferring Java class names.Default is no custom mappings, i.e. transferring raw Java class names.
- Parameters:
typeIdMappings
- a Map with type id values as keys and Java classes as values
-
setBeanClassLoader
Description copied from interface:BeanClassLoaderAware
Callback that supplies the beanclass loader
to a bean instance.Invoked after the population of normal bean properties but before an initialization callback such as
InitializingBean's
InitializingBean.afterPropertiesSet()
method or a custom init-method.- Specified by:
setBeanClassLoader
in interfaceBeanClassLoaderAware
- Parameters:
classLoader
- the owning class loader
-
toMessage
public jakarta.jms.Message toMessage(Object object, jakarta.jms.Session session) throws jakarta.jms.JMSException, MessageConversionException Description copied from interface:MessageConverter
Convert a Java object to a JMS Message using the supplied session to create the message object.- Specified by:
toMessage
in interfaceMessageConverter
- Parameters:
object
- the object to convertsession
- the Session to use for creating a JMS Message- Returns:
- the JMS Message
- Throws:
jakarta.jms.JMSException
- if thrown by JMS API methodsMessageConversionException
- in case of conversion failure
-
toMessage
public jakarta.jms.Message toMessage(Object object, jakarta.jms.Session session, @Nullable Object conversionHint) throws jakarta.jms.JMSException, MessageConversionException Description copied from interface:SmartMessageConverter
A variant ofMessageConverter.toMessage(Object, Session)
which takes an extra conversion context as an argument, allowing to take, for example, annotations on a payload parameter into account.- Specified by:
toMessage
in interfaceSmartMessageConverter
- Parameters:
object
- the object to convertsession
- the Session to use for creating a JMS MessageconversionHint
- an extra object passed to theMessageConverter
, for example, the associatedMethodParameter
(may benull
)- Returns:
- the JMS Message
- Throws:
jakarta.jms.JMSException
- if thrown by JMS API methodsMessageConversionException
- in case of conversion failure- See Also:
-
toMessage
public jakarta.jms.Message toMessage(Object object, jakarta.jms.Session session, @Nullable Class<?> jsonView) throws jakarta.jms.JMSException, MessageConversionException Convert a Java object to a JMS Message using the specified json view and the supplied session to create the message object.- Parameters:
object
- the object to convertsession
- the Session to use for creating a JMS MessagejsonView
- the view to use to filter the content- Returns:
- the JMS Message
- Throws:
jakarta.jms.JMSException
- if thrown by JMS API methodsMessageConversionException
- in case of conversion failure
-
fromMessage
public Object fromMessage(jakarta.jms.Message message) throws jakarta.jms.JMSException, MessageConversionException Description copied from interface:MessageConverter
Convert from a JMS Message to a Java object.- Specified by:
fromMessage
in interfaceMessageConverter
- Parameters:
message
- the message to convert- Returns:
- the converted Java object
- Throws:
jakarta.jms.JMSException
- if thrown by JMS API methodsMessageConversionException
- in case of conversion failure
-
toMessage
protected jakarta.jms.Message toMessage(Object object, jakarta.jms.Session session, tools.jackson.databind.ObjectWriter objectWriter) throws jakarta.jms.JMSException, MessageConversionException - Throws:
jakarta.jms.JMSException
MessageConversionException
-
mapToTextMessage
protected jakarta.jms.TextMessage mapToTextMessage(Object object, jakarta.jms.Session session, tools.jackson.databind.ObjectWriter objectWriter) throws jakarta.jms.JMSException, IOException Map the given object to aTextMessage
.- Parameters:
object
- the object to be mappedsession
- current JMS sessionobjectWriter
- the writer to use- Returns:
- the resulting message
- Throws:
jakarta.jms.JMSException
- if thrown by JMS methodsIOException
- in case of I/O errors- See Also:
-
mapToBytesMessage
protected jakarta.jms.BytesMessage mapToBytesMessage(Object object, jakarta.jms.Session session, tools.jackson.databind.ObjectWriter objectWriter) throws jakarta.jms.JMSException, IOException Map the given object to aBytesMessage
.- Parameters:
object
- the object to be mappedsession
- current JMS sessionobjectWriter
- the writer to use- Returns:
- the resulting message
- Throws:
jakarta.jms.JMSException
- if thrown by JMS methodsIOException
- in case of I/O errors- See Also:
-
mapToMessage
protected jakarta.jms.Message mapToMessage(Object object, jakarta.jms.Session session, tools.jackson.databind.ObjectWriter objectWriter, MessageType targetType) throws jakarta.jms.JMSException, IOException Template method that allows for custom message mapping. Invoked whensetTargetType(MessageType)
is notMessageType.TEXT
orMessageType.BYTES
.The default implementation throws an
IllegalArgumentException
.- Parameters:
object
- the object to marshalsession
- the JMS SessionobjectWriter
- the writer to usetargetType
- the target message type (other than TEXT or BYTES)- Returns:
- the resulting message
- Throws:
jakarta.jms.JMSException
- if thrown by JMS methodsIOException
- in case of I/O errors
-
setTypeIdOnMessage
protected void setTypeIdOnMessage(Object object, jakarta.jms.Message message) throws jakarta.jms.JMSException Set a type id for the given payload object on the given JMS Message.The default implementation consults the configured type id mapping and sets the resulting value (either a mapped id or the raw Java class name) into the configured type id message property.
- Parameters:
object
- the payload object to set a type id formessage
- the JMS Message on which to set the type id property- Throws:
jakarta.jms.JMSException
- if thrown by JMS methods- See Also:
-
convertFromTextMessage
protected Object convertFromTextMessage(jakarta.jms.TextMessage message, tools.jackson.databind.JavaType targetJavaType) throws jakarta.jms.JMSException, IOException Convert a TextMessage to a Java Object with the specified type.- Parameters:
message
- the input messagetargetJavaType
- the target type- Returns:
- the message converted to an object
- Throws:
jakarta.jms.JMSException
- if thrown by JMSIOException
- in case of I/O errors
-
convertFromBytesMessage
protected Object convertFromBytesMessage(jakarta.jms.BytesMessage message, tools.jackson.databind.JavaType targetJavaType) throws jakarta.jms.JMSException, IOException Convert a BytesMessage to a Java Object with the specified type.- Parameters:
message
- the input messagetargetJavaType
- the target type- Returns:
- the message converted to an object
- Throws:
jakarta.jms.JMSException
- if thrown by JMSIOException
- in case of I/O errors
-
convertFromMessage
protected Object convertFromMessage(jakarta.jms.Message message, tools.jackson.databind.JavaType targetJavaType) throws jakarta.jms.JMSException, IOException Template method that allows for custom message mapping. Invoked whensetTargetType(MessageType)
is notMessageType.TEXT
orMessageType.BYTES
.The default implementation throws an
IllegalArgumentException
.- Parameters:
message
- the input messagetargetJavaType
- the target type- Returns:
- the message converted to an object
- Throws:
jakarta.jms.JMSException
- if thrown by JMSIOException
- in case of I/O errors
-
getJavaTypeForMessage
protected tools.jackson.databind.JavaType getJavaTypeForMessage(jakarta.jms.Message message) throws jakarta.jms.JMSException Determine a Jackson JavaType for the given JMS Message, typically parsing a type id message property.The default implementation parses the configured type id property name and consults the configured type id mapping. This can be overridden with a different strategy, for example, doing some heuristics based on message origin.
- Parameters:
message
- the JMS Message from which to get the type id property- Throws:
jakarta.jms.JMSException
- if thrown by JMS methods- See Also:
-
getSerializationView
Determine a Jackson serialization view based on the given conversion hint.- Parameters:
conversionHint
- the conversion hint Object as passed into the converter for the current conversion attempt- Returns:
- the serialization view class, or
null
if none
-