Class JsonMessageConverter
java.lang.Object
org.springframework.kafka.support.converter.MessagingMessageConverter
org.springframework.kafka.support.converter.JsonMessageConverter
- All Implemented Interfaces:
MessageConverter,RecordMessageConverter
- Direct Known Subclasses:
ByteArrayJsonMessageConverter,BytesJsonMessageConverter,StringJsonMessageConverter
Base class for JSON message converters; on the consumer side, it can
handle
byte[], Bytes and String record values.
On the producer side, select a subclass that matches the corresponding
Kafka Serializer.- Since:
- 2.3
- Author:
- Gary Russell
-
Field Summary
Fields inherited from class org.springframework.kafka.support.converter.MessagingMessageConverter
logger -
Constructor Summary
ConstructorsConstructorDescriptionJsonMessageConverter(com.fasterxml.jackson.databind.ObjectMapper objectMapper) -
Method Summary
Modifier and TypeMethodDescriptionprotected ObjectconvertPayload(Message<?> message) Subclasses can convert the payload; by default, it's sent unchanged to Kafka.protected ObjectextractAndConvertValue(org.apache.kafka.clients.consumer.ConsumerRecord<?, ?> record, Type type) Subclasses can convert the value; by default, it's returned as provided by Kafka unless there is aSmartMessageConverterthat can convert it.protected com.fasterxml.jackson.databind.ObjectMapperReturn the object mapper.protected org.apache.kafka.common.header.HeadersinitialRecordHeaders(Message<?> message) Subclasses can populate additional headers before they are mapped.voidsetTypeMapper(Jackson2JavaTypeMapper typeMapper) Set a customized type mapper.Methods inherited from class org.springframework.kafka.support.converter.MessagingMessageConverter
fromMessage, getMessagingConverter, setGenerateMessageId, setGenerateTimestamp, setHeaderMapper, setMessagingConverter, setRawRecordHeader, toMessageMethods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface org.springframework.kafka.support.converter.MessageConverter
commonHeaders
-
Constructor Details
-
JsonMessageConverter
public JsonMessageConverter() -
JsonMessageConverter
public JsonMessageConverter(com.fasterxml.jackson.databind.ObjectMapper objectMapper)
-
-
Method Details
-
getTypeMapper
-
setTypeMapper
Set a customized type mapper.- Parameters:
typeMapper- the type mapper.
-
getObjectMapper
protected com.fasterxml.jackson.databind.ObjectMapper getObjectMapper()Return the object mapper.- Returns:
- the mapper.
-
initialRecordHeaders
Description copied from class:MessagingMessageConverterSubclasses can populate additional headers before they are mapped.- Overrides:
initialRecordHeadersin classMessagingMessageConverter- Parameters:
message- the message.- Returns:
- the headers
-
convertPayload
Description copied from class:MessagingMessageConverterSubclasses can convert the payload; by default, it's sent unchanged to Kafka.- Overrides:
convertPayloadin classMessagingMessageConverter- Parameters:
message- the message.- Returns:
- the payload.
-
extractAndConvertValue
protected Object extractAndConvertValue(org.apache.kafka.clients.consumer.ConsumerRecord<?, ?> record, Type type) Description copied from class:MessagingMessageConverterSubclasses can convert the value; by default, it's returned as provided by Kafka unless there is aSmartMessageConverterthat can convert it.- Overrides:
extractAndConvertValuein classMessagingMessageConverter- Parameters:
record- the record.type- the required type.- Returns:
- the value.
-