Class MessageBuilder<T>
java.lang.Object
org.springframework.integration.support.AbstractIntegrationMessageBuilder<T>
org.springframework.integration.support.MessageBuilder<T>
- Type Parameters:
- T- the payload type.
public final class MessageBuilder<T> extends AbstractIntegrationMessageBuilder<T>
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 SummaryModifier and Type Method Description Message<T>build()MessageBuilder<T>copyHeaders(Map<String,?> headersToCopy)Copy the name-value pairs from the provided Map.MessageBuilder<T>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 ObjectgetCorrelationId()<V> VgetHeader(String key, Class<V> type)Map<String,Object>getHeaders()TgetPayload()protected List<List<Object>>getSequenceDetails()protected ObjectgetSequenceNumber()protected ObjectgetSequenceSize()MessageBuilder<T>popSequenceDetails()MessageBuilder<T>pushSequenceDetails(Object correlationId, int sequenceNumber, int sequenceSize)MessageBuilder<T>readOnlyHeaders(String... readOnlyHeaders)Specify a list of headers which should be considered as read only and prohibited from being populated in the message.MessageBuilder<T>removeHeader(String headerName)Remove the value for the given header name.MessageBuilder<T>removeHeaders(String... headerPatterns)Removes all headers provided via array of 'headerPatterns'.MessageBuilder<T>setCorrelationId(Object correlationId)MessageBuilder<T>setErrorChannel(MessageChannel errorChannel)MessageBuilder<T>setErrorChannelName(String errorChannelName)MessageBuilder<T>setExpirationDate(Long expirationDate)MessageBuilder<T>setExpirationDate(Date expirationDate)MessageBuilder<T>setHeader(String headerName, Object headerValue)Set the value for the given header name.MessageBuilder<T>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.MessageBuilder<T>setPriority(Integer priority)MessageBuilder<T>setReplyChannel(MessageChannel replyChannel)MessageBuilder<T>setReplyChannelName(String replyChannelName)MessageBuilder<T>setSequenceNumber(Integer sequenceNumber)MessageBuilder<T>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.AbstractIntegrationMessageBuilderfilterAndCopyHeadersIfAbsent
- 
Method Details- 
getPayload- Specified by:
- getPayloadin class- AbstractIntegrationMessageBuilder<T>
 
- 
getHeaders- Specified by:
- getHeadersin class- AbstractIntegrationMessageBuilder<T>
 
- 
getHeader- Specified by:
- getHeaderin class- AbstractIntegrationMessageBuilder<T>
 
- 
fromMessageCreate 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.
 
- 
withPayloadCreate 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.
 
- 
setHeaderSet the value for the given header name. If the provided value isnull, the header will be removed.- Specified by:
- setHeaderin class- AbstractIntegrationMessageBuilder<T>
- Parameters:
- headerName- The header name.
- headerValue- The header value.
- Returns:
- this MessageBuilder.
 
- 
setHeaderIfAbsentSet the value for the given header name only if the header name is not already associated with a value.- Specified by:
- setHeaderIfAbsentin class- AbstractIntegrationMessageBuilder<T>
- Parameters:
- headerName- The header name.
- headerValue- The header value.
- Returns:
- this MessageBuilder.
 
- 
removeHeadersRemoves 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 class- AbstractIntegrationMessageBuilder<T>
- Parameters:
- headerPatterns- The header patterns.
- Returns:
- this MessageBuilder.
 
- 
removeHeaderRemove the value for the given header name.- Specified by:
- removeHeaderin class- AbstractIntegrationMessageBuilder<T>
- Parameters:
- headerName- The header name.
- Returns:
- this MessageBuilder.
 
- 
copyHeadersCopy 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 class- AbstractIntegrationMessageBuilder<T>
- Parameters:
- headersToCopy- The headers to copy.
- Returns:
- this MessageBuilder.
- See Also:
- MessageHeaders.ID,- MessageHeaders.TIMESTAMP
 
- 
copyHeadersIfAbsentCopy the name-value pairs from the provided Map. This operation will not overwrite any existing values.- Specified by:
- copyHeadersIfAbsentin class- AbstractIntegrationMessageBuilder<T>
- Parameters:
- headersToCopy- The headers to copy.
- Returns:
- this MessageBuilder.
 
- 
getSequenceDetails- Specified by:
- getSequenceDetailsin class- AbstractIntegrationMessageBuilder<T>
 
- 
getCorrelationId- Specified by:
- getCorrelationIdin class- AbstractIntegrationMessageBuilder<T>
 
- 
getSequenceNumber- Specified by:
- getSequenceNumberin class- AbstractIntegrationMessageBuilder<T>
 
- 
getSequenceSize- Specified by:
- getSequenceSizein class- AbstractIntegrationMessageBuilder<T>
 
- 
pushSequenceDetailspublic MessageBuilder<T> pushSequenceDetails(Object correlationId, int sequenceNumber, int sequenceSize)- Overrides:
- pushSequenceDetailsin class- AbstractIntegrationMessageBuilder<T>
 
- 
popSequenceDetails- Overrides:
- popSequenceDetailsin class- AbstractIntegrationMessageBuilder<T>
 
- 
setExpirationDate- Overrides:
- setExpirationDatein class- AbstractIntegrationMessageBuilder<T>
 
- 
setExpirationDate- Overrides:
- setExpirationDatein class- AbstractIntegrationMessageBuilder<T>
 
- 
setCorrelationId- Overrides:
- setCorrelationIdin class- AbstractIntegrationMessageBuilder<T>
 
- 
setReplyChannel- Overrides:
- setReplyChannelin class- AbstractIntegrationMessageBuilder<T>
 
- 
setReplyChannelName- Overrides:
- setReplyChannelNamein class- AbstractIntegrationMessageBuilder<T>
 
- 
setErrorChannel- Overrides:
- setErrorChannelin class- AbstractIntegrationMessageBuilder<T>
 
- 
setErrorChannelName- Overrides:
- setErrorChannelNamein class- AbstractIntegrationMessageBuilder<T>
 
- 
setSequenceNumber- Overrides:
- setSequenceNumberin class- AbstractIntegrationMessageBuilder<T>
 
- 
setSequenceSize- Overrides:
- setSequenceSizein class- AbstractIntegrationMessageBuilder<T>
 
- 
setPriority- Overrides:
- setPriorityin class- AbstractIntegrationMessageBuilder<T>
 
- 
readOnlyHeadersSpecify 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 for- readOnlymode. Defaults to- MessageHeaders.IDand- MessageHeaders.TIMESTAMP.
- Returns:
- the current MessageBuilder
- Since:
- 4.3.2
- See Also:
- IntegrationMessageHeaderAccessor.isReadOnly(String)
 
- 
build- Specified by:
- buildin class- AbstractIntegrationMessageBuilder<T>
 
 
-