Class MessageBuilder<T>
java.lang.Object
org.springframework.integration.support.AbstractIntegrationMessageBuilder<T>
org.springframework.integration.support.MessageBuilder<T>
- Type Parameters:
T- the payload type.
The default message builder; creates immutable
GenericMessages.
Named MessageBuilder instead of DefaultMessageBuilder for backwards
compatibility.- Author:
- Arjen Poutsma, Mark Fisher, Oleg Zhurakousky, Dave Syer, Gary Russell, Artem Bilan
-
Method Summary
Modifier and TypeMethodDescriptionbuild()copyHeaders(Map<String, ?> headersToCopy) Copy the name-value pairs from the provided Map.copyHeadersIfAbsent(Map<String, ?> headersToCopy) Copy the name-value pairs from the provided Map.static <T> MessageBuilder<T> fromMessage(Message<T> message) Create a builder for a newMessageinstance pre-populated with all of the headers copied from the provided message.protected Object<V> Vprotected Objectprotected ObjectpushSequenceDetails(Object correlationId, int sequenceNumber, int sequenceSize) readOnlyHeaders(String... readOnlyHeaders) Specify a list of headers which should be considered as read only and prohibited from being populated in the message.removeHeader(String headerName) Remove the value for the given header name.removeHeaders(String... headerPatterns) Removes all headers provided via array of 'headerPatterns'.setCorrelationId(Object correlationId) setErrorChannel(MessageChannel errorChannel) setErrorChannelName(String errorChannelName) setExpirationDate(Long expirationDate) setExpirationDate(Date expirationDate) Set the value for the given header name.setHeaderIfAbsent(String headerName, Object headerValue) Set the value for the given header name only if the header name is not already associated with a value.setPriority(Integer priority) setReplyChannel(MessageChannel replyChannel) setReplyChannelName(String replyChannelName) setSequenceNumber(Integer sequenceNumber) setSequenceSize(Integer sequenceSize) static <T> MessageBuilder<T> withPayload(T payload) Create a builder for a newMessageinstance with the provided payload.Methods inherited from class org.springframework.integration.support.AbstractIntegrationMessageBuilder
cloneMessageHistoryIfAny, filterAndCopyHeadersIfAbsent
-
Method Details
-
getPayload
- Specified by:
getPayloadin classAbstractIntegrationMessageBuilder<T>
-
getHeaders
- Specified by:
getHeadersin classAbstractIntegrationMessageBuilder<T>
-
getHeader
-
fromMessage
Create a builder for a newMessageinstance pre-populated with all of the headers copied from the provided message. The payload of the provided Message will also be used as the payload for the new message.- Type Parameters:
T- The type of the payload.- Parameters:
message- the Message from which the payload and all headers will be copied- Returns:
- A MessageBuilder.
-
withPayload
Create a builder for a newMessageinstance with the provided payload.- Type Parameters:
T- The type of the payload.- Parameters:
payload- the payload for the new message- Returns:
- A MessageBuilder.
-
setHeader
Set the value for the given header name. If the provided value isnull, the header will be removed.- Specified by:
setHeaderin classAbstractIntegrationMessageBuilder<T>- Parameters:
headerName- The header name.headerValue- The header value.- Returns:
- this MessageBuilder.
-
setHeaderIfAbsent
Set the value for the given header name only if the header name is not already associated with a value.- Specified by:
setHeaderIfAbsentin classAbstractIntegrationMessageBuilder<T>- Parameters:
headerName- The header name.headerValue- The header value.- Returns:
- this MessageBuilder.
-
removeHeaders
Removes all headers provided via array of 'headerPatterns'. As the name suggests the array may contain simple matching patterns for header names. Supported pattern styles are: "xxx*", "*xxx", "*xxx*" and "xxx*yyy".- Specified by:
removeHeadersin classAbstractIntegrationMessageBuilder<T>- Parameters:
headerPatterns- The header patterns.- Returns:
- this MessageBuilder.
-
removeHeader
Remove the value for the given header name.- Specified by:
removeHeaderin classAbstractIntegrationMessageBuilder<T>- Parameters:
headerName- The header name.- Returns:
- this MessageBuilder.
-
copyHeaders
Copy the name-value pairs from the provided Map. This operation will overwrite any existing values. Use {copyHeadersIfAbsent(Map)to avoid overwriting values. Note that the 'id' and 'timestamp' header values will never be overwritten.- Specified by:
copyHeadersin classAbstractIntegrationMessageBuilder<T>- Parameters:
headersToCopy- The headers to copy.- Returns:
- this MessageBuilder.
- See Also:
-
copyHeadersIfAbsent
Copy the name-value pairs from the provided Map. This operation will not overwrite any existing values.- Specified by:
copyHeadersIfAbsentin classAbstractIntegrationMessageBuilder<T>- Parameters:
headersToCopy- The headers to copy.- Returns:
- this MessageBuilder.
-
getSequenceDetails
- Specified by:
getSequenceDetailsin classAbstractIntegrationMessageBuilder<T>
-
getCorrelationId
- Specified by:
getCorrelationIdin classAbstractIntegrationMessageBuilder<T>
-
getSequenceNumber
- Specified by:
getSequenceNumberin classAbstractIntegrationMessageBuilder<T>
-
getSequenceSize
- Specified by:
getSequenceSizein classAbstractIntegrationMessageBuilder<T>
-
pushSequenceDetails
public MessageBuilder<T> pushSequenceDetails(Object correlationId, int sequenceNumber, int sequenceSize) - Overrides:
pushSequenceDetailsin classAbstractIntegrationMessageBuilder<T>
-
popSequenceDetails
- Overrides:
popSequenceDetailsin classAbstractIntegrationMessageBuilder<T>
-
setExpirationDate
- Overrides:
setExpirationDatein classAbstractIntegrationMessageBuilder<T>
-
setExpirationDate
- Overrides:
setExpirationDatein classAbstractIntegrationMessageBuilder<T>
-
setCorrelationId
- Overrides:
setCorrelationIdin classAbstractIntegrationMessageBuilder<T>
-
setReplyChannel
- Overrides:
setReplyChannelin classAbstractIntegrationMessageBuilder<T>
-
setReplyChannelName
- Overrides:
setReplyChannelNamein classAbstractIntegrationMessageBuilder<T>
-
setErrorChannel
- Overrides:
setErrorChannelin classAbstractIntegrationMessageBuilder<T>
-
setErrorChannelName
- Overrides:
setErrorChannelNamein classAbstractIntegrationMessageBuilder<T>
-
setSequenceNumber
- Overrides:
setSequenceNumberin classAbstractIntegrationMessageBuilder<T>
-
setSequenceSize
- Overrides:
setSequenceSizein classAbstractIntegrationMessageBuilder<T>
-
setPriority
- Overrides:
setPriorityin classAbstractIntegrationMessageBuilder<T>
-
readOnlyHeaders
Specify a list of headers which should be considered as read only and prohibited from being populated in the message.- Parameters:
readOnlyHeaders- the list of headers forreadOnlymode. Defaults toMessageHeaders.IDandMessageHeaders.TIMESTAMP.- Returns:
- the current
MessageBuilder - Since:
- 4.3.2
- See Also:
-
build
- Specified by:
buildin classAbstractIntegrationMessageBuilder<T>
-