Class ActiveMQMapMessage
- All Implemented Interfaces:
jakarta.jms.MapMessage,jakarta.jms.Message,MessageReference,Command,DataStructure,MarshallAware,Message,ScheduledMessage
MapMessage object is used to send a set of name-value pairs.
The names are String objects, and the values are primitive
data types in the Java programming language. The names must have a value that
is not null, and not an empty string. The entries can be accessed
sequentially or randomly by name. The order of the entries is undefined.
MapMessage inherits from the Message interface
and adds a message body that contains a Map.
The primitive types can be read or written explicitly using methods for each
type. They may also be read or written generically as objects. For instance,
a call to MapMessage.setInt("foo", 6) is equivalent to
MapMessage.setObject("foo", new Integer(6)). Both forms are
provided, because the explicit form is convenient for static programming, and
the object form is needed when types are not known at compile time.
When a client receives a MapMessage, it is in read-only mode.
If a client attempts to write to the message at this point, a
MessageNotWriteableException is thrown. If
clearBody is called, the message can now be both read from and
written to.
MapMessage objects support the following conversion table. The
marked cases must be supported. The unmarked cases must throw a
JMSException. The String -to-primitive
conversions may throw a runtime exception if the primitive's
valueOf() method does not accept it as a valid
String representation of the primitive.
A value written as the row type can be read as the column type.
| | boolean byte short char int long float double String byte[] |---------------------------------------------------------------------- |boolean | X X |byte | X X X X X |short | X X X X |char | X X |int | X X X |long | X X |float | X X X |double | X X |String | X X X X X X X X |byte[] | X |---------------------------------------------------------------------- <p/>
Attempting to read a null value as a primitive type must be treated as
calling the primitive's corresponding valueOf(String)
conversion method with a null value. Since char does not
support a String conversion, attempting to read a null value
as a char must throw a NullPointerException.
- See Also:
-
Session.createMapMessage()BytesMessageMessageObjectMessageStreamMessageTextMessage
-
Nested Class Summary
Nested classes/interfaces inherited from class org.apache.activemq.command.Message
Message.MessageDestination -
Field Summary
FieldsModifier and TypeFieldDescriptionstatic final byteFields inherited from class org.apache.activemq.command.ActiveMQMessage
acknowledgeCallback, BROKER_PATH_PROPERTY, DLQ_DELIVERY_FAILURE_CAUSE_PROPERTYFields inherited from class org.apache.activemq.command.Message
arrival, brokerInTime, brokerOutTime, compressed, content, correlationId, dataStructure, DEFAULT_MINIMUM_MESSAGE_SIZE, deliveryTime, destination, droppable, expiration, groupID, groupSequence, jmsXGroupFirstForConsumer, marshalledProperties, messageId, ORIGINAL_EXPIRATION, originalDestination, originalTransactionId, persistent, priority, producerId, properties, readOnlyBody, readOnlyProperties, recievedByDFBridge, redeliveryCounter, replyTo, size, targetConsumerId, timestamp, transactionId, type, userIDFields inherited from class org.apache.activemq.command.BaseCommand
commandId, responseRequiredFields inherited from interface jakarta.jms.Message
DEFAULT_DELIVERY_DELAY, DEFAULT_DELIVERY_MODE, DEFAULT_PRIORITY, DEFAULT_TIME_TO_LIVEFields inherited from interface org.apache.activemq.ScheduledMessage
AMQ_SCHEDULED_CRON, AMQ_SCHEDULED_DELAY, AMQ_SCHEDULED_ID, AMQ_SCHEDULED_PERIOD, AMQ_SCHEDULED_REPEAT, AMQ_SCHEDULER_ACTION, AMQ_SCHEDULER_ACTION_BROWSE, AMQ_SCHEDULER_ACTION_END_TIME, AMQ_SCHEDULER_ACTION_REMOVE, AMQ_SCHEDULER_ACTION_REMOVEALL, AMQ_SCHEDULER_ACTION_START_TIME, AMQ_SCHEDULER_MANAGEMENT_DESTINATION -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionvoidbeforeMarshall(WireFormat wireFormat) voidClears out the message body.voidvoidcompress()copy()protected <T> TbooleangetBoolean(String name) Returns thebooleanvalue with the specified name.byteReturns thebytevalue with the specified name.byte[]Returns the byte array value with the specified name.charReturns the Unicode character value with the specified name.bytedoubleReturns thedoublevalue with the specified name.floatReturns thefloatvalue with the specified name.intReturns theintvalue with the specified name.Returns the MIME type of this mesage.longReturns thelongvalue with the specified name.Returns anEnumerationof all the names in theMapMessageobject.Returns the value of the object with the specified name.shortReturns theshortvalue with the specified name.Returns theStringvalue with the specified name.booleanbooleanbooleanitemExists(String name) Indicates whether an item exists in thisMapMessageobject.protected voidprotected ObjectInitialize the transient fields at deserialization to get a normal state.voidsetBoolean(String name, boolean value) Sets abooleanvalue with the specified name into the Map.voidSets abytevalue with the specified name into the Map.voidSets a byte array value with the specified name into the Map.voidSets a portion of the byte array value with the specified name into the Map.voidSets a Unicode character value with the specified name into the Map.voidSets adoublevalue with the specified name into the Map.voidSets afloatvalue with the specified name into the Map.voidSets anintvalue with the specified name into the Map.voidSets alongvalue with the specified name into the Map.voidSets an object value with the specified name into the Map.voidSets ashortvalue with the specified name into the Map.voidSets aStringvalue with the specified name into the Map.voidvoidtoString()Methods inherited from class org.apache.activemq.command.ActiveMQMessage
acknowledge, checkReadOnlyBody, checkReadOnlyProperties, checkValidObject, clearProperties, convertScheduled, copy, decodeString, encodeString, equals, getAcknowledgeCallback, getAllPropertyNames, getBody, getBooleanProperty, getByteProperty, getDoubleProperty, getFloatProperty, getIntProperty, getJMSCorrelationID, getJMSCorrelationIDAsBytes, getJMSDeliveryMode, getJMSDeliveryTime, getJMSDestination, getJMSExpiration, getJMSMessageID, getJMSPriority, getJMSRedelivered, getJMSReplyTo, getJMSTimestamp, getJMSType, getLongProperty, getObjectProperty, getPropertyNames, getShortProperty, getStringProperty, hashCode, onSend, propertyExists, setAcknowledgeCallback, setBooleanProperty, setBooleanProperty, setByteProperty, setDoubleProperty, setFloatProperty, setIntProperty, setJMSCorrelationID, setJMSCorrelationIDAsBytes, setJMSDeliveryMode, setJMSDeliveryTime, setJMSDestination, setJMSExpiration, setJMSMessageID, setJMSMessageID, setJMSPriority, setJMSRedelivered, setJMSReplyTo, setJMSTimestamp, setJMSType, setLongProperty, setObjectProperty, setObjectProperty, setProperties, setShortProperty, setStringProperty, visitMethods inherited from class org.apache.activemq.command.Message
afterMarshall, afterUnmarshall, beforeUnmarshall, canProcessAsExpired, copy, decrementReferenceCount, doCompress, getArrival, getBrokerInTime, getBrokerOutTime, getBrokerPath, getCluster, getConnection, getContent, getCorrelationId, getDataStructure, getDestination, getExpiration, getGroupID, getGroupSequence, getMarshalledProperties, getMemoryUsage, getMessage, getMessageHardRef, getMessageId, getMinimumMessageSize, getOriginalDestination, getOriginalTransactionId, getPriority, getProducerId, getProperties, getProperty, getRedeliveryCounter, getReferenceCount, getRegionDestination, getReplyTo, getSize, getTargetConsumerId, getTimestamp, getTransactionId, getType, getUserID, incrementRedeliveryCounter, incrementReferenceCount, isAdvisory, isCompressed, isDroppable, isDropped, isExpired, isInTransaction, isJMSXGroupFirstForConsumer, isMarshallAware, isMarshalled, isMessage, isPersistent, isPropertiesMarshalled, isReadOnlyBody, isReadOnlyProperties, isRecievedByDFBridge, isRedelivered, lazyCreateProperties, onMessageRolledBack, removeProperty, setArrival, setBrokerInTime, setBrokerOutTime, setBrokerPath, setCluster, setCompressed, setConnection, setContent, setCorrelationId, setDataStructure, setDestination, setDroppable, setExpiration, setGroupID, setGroupSequence, setJMSXGroupFirstForConsumer, setMarshalledProperties, setMemoryUsage, setMessageId, setOriginalDestination, setOriginalTransactionId, setPersistent, setPriority, setProducerId, setProperty, setReadOnlyBody, setReadOnlyProperties, setRecievedByDFBridge, setRedelivered, setRedeliveryCounter, setRegionDestination, setReplyTo, setTargetConsumerId, setTimestamp, setTransactionId, setType, setUserID, toStringMethods inherited from class org.apache.activemq.command.BaseCommand
copy, getCommandId, getFrom, getTo, isBrokerInfo, isConnectionControl, isConsumerControl, isMessageAck, isMessageDispatch, isMessageDispatchNotification, isResponse, isResponseRequired, isShutdownInfo, isWireFormatInfo, setCommandId, setFrom, setResponseRequired, setToMethods inherited from class java.lang.Object
clone, finalize, getClass, notify, notifyAll, wait, wait, waitMethods inherited from interface jakarta.jms.Message
acknowledge, clearProperties, getBody, getBooleanProperty, getByteProperty, getDoubleProperty, getFloatProperty, getIntProperty, getJMSCorrelationID, getJMSCorrelationIDAsBytes, getJMSDeliveryMode, getJMSDeliveryTime, getJMSDestination, getJMSExpiration, getJMSMessageID, getJMSPriority, getJMSRedelivered, getJMSReplyTo, getJMSTimestamp, getJMSType, getLongProperty, getObjectProperty, getPropertyNames, getShortProperty, getStringProperty, propertyExists, setBooleanProperty, setByteProperty, setDoubleProperty, setFloatProperty, setIntProperty, setJMSCorrelationID, setJMSCorrelationIDAsBytes, setJMSDeliveryMode, setJMSDeliveryTime, setJMSDestination, setJMSExpiration, setJMSMessageID, setJMSPriority, setJMSRedelivered, setJMSReplyTo, setJMSTimestamp, setJMSType, setLongProperty, setObjectProperty, setShortProperty, setStringProperty
-
Field Details
-
DATA_STRUCTURE_TYPE
public static final byte DATA_STRUCTURE_TYPE- See Also:
-
map
-
-
Constructor Details
-
ActiveMQMapMessage
public ActiveMQMapMessage()
-
-
Method Details
-
readResolve
Description copied from class:MessageInitialize the transient fields at deserialization to get a normal state.- Overrides:
readResolvein classMessage- Throws:
ObjectStreamException- See Also:
-
copy
- Overrides:
copyin classActiveMQMessage
-
beforeMarshall
- Specified by:
beforeMarshallin interfaceMarshallAware- Overrides:
beforeMarshallin classMessage- Throws:
IOException
-
clearUnMarshalledState
public void clearUnMarshalledState() throws jakarta.jms.JMSException- Overrides:
clearUnMarshalledStatein classMessage- Throws:
jakarta.jms.JMSException
-
storeContentAndClear
public void storeContentAndClear()- Overrides:
storeContentAndClearin classActiveMQMessage
-
storeContent
public void storeContent()- Overrides:
storeContentin classActiveMQMessage
-
isContentMarshalled
public boolean isContentMarshalled()- Overrides:
isContentMarshalledin classActiveMQMessage
-
getDataStructureType
public byte getDataStructureType()- Specified by:
getDataStructureTypein interfaceDataStructure- Overrides:
getDataStructureTypein classActiveMQMessage- Returns:
- The type of the data structure
-
getJMSXMimeType
Description copied from interface:MessageReturns the MIME type of this mesage. This can be used in selectors to filter on the MIME types of the different JMS messages, or in the case ofBlobMessageit allows you to create a selector on the MIME type of the BLOB body- Specified by:
getJMSXMimeTypein interfaceMessage- Overrides:
getJMSXMimeTypein classActiveMQMessage
-
clearBody
public void clearBody() throws jakarta.jms.JMSExceptionClears out the message body. Clearing a message's body does not clear its header values or property entries.If this message body was read-only, calling this method leaves the message body in the same state as an empty body in a newly created message.
- Specified by:
clearBodyin interfacejakarta.jms.Message- Overrides:
clearBodyin classActiveMQMessage- Throws:
jakarta.jms.JMSException
-
getBoolean
Returns thebooleanvalue with the specified name.- Specified by:
getBooleanin interfacejakarta.jms.MapMessage- Parameters:
name- the name of theboolean- Returns:
- the
booleanvalue with the specified name - Throws:
jakarta.jms.JMSException- if the JMS provider fails to read the message due to some internal error.jakarta.jms.MessageFormatException- if this type conversion is invalid.
-
getByte
Returns thebytevalue with the specified name.- Specified by:
getBytein interfacejakarta.jms.MapMessage- Parameters:
name- the name of thebyte- Returns:
- the
bytevalue with the specified name - Throws:
jakarta.jms.JMSException- if the JMS provider fails to read the message due to some internal error.jakarta.jms.MessageFormatException- if this type conversion is invalid.
-
getShort
Returns theshortvalue with the specified name.- Specified by:
getShortin interfacejakarta.jms.MapMessage- Parameters:
name- the name of theshort- Returns:
- the
shortvalue with the specified name - Throws:
jakarta.jms.JMSException- if the JMS provider fails to read the message due to some internal error.jakarta.jms.MessageFormatException- if this type conversion is invalid.
-
getChar
Returns the Unicode character value with the specified name.- Specified by:
getCharin interfacejakarta.jms.MapMessage- Parameters:
name- the name of the Unicode character- Returns:
- the Unicode character value with the specified name
- Throws:
jakarta.jms.JMSException- if the JMS provider fails to read the message due to some internal error.jakarta.jms.MessageFormatException- if this type conversion is invalid.
-
getInt
Returns theintvalue with the specified name.- Specified by:
getIntin interfacejakarta.jms.MapMessage- Parameters:
name- the name of theint- Returns:
- the
intvalue with the specified name - Throws:
jakarta.jms.JMSException- if the JMS provider fails to read the message due to some internal error.jakarta.jms.MessageFormatException- if this type conversion is invalid.
-
getLong
Returns thelongvalue with the specified name.- Specified by:
getLongin interfacejakarta.jms.MapMessage- Parameters:
name- the name of thelong- Returns:
- the
longvalue with the specified name - Throws:
jakarta.jms.JMSException- if the JMS provider fails to read the message due to some internal error.jakarta.jms.MessageFormatException- if this type conversion is invalid.
-
getFloat
Returns thefloatvalue with the specified name.- Specified by:
getFloatin interfacejakarta.jms.MapMessage- Parameters:
name- the name of thefloat- Returns:
- the
floatvalue with the specified name - Throws:
jakarta.jms.JMSException- if the JMS provider fails to read the message due to some internal error.jakarta.jms.MessageFormatException- if this type conversion is invalid.
-
getDouble
Returns thedoublevalue with the specified name.- Specified by:
getDoublein interfacejakarta.jms.MapMessage- Parameters:
name- the name of thedouble- Returns:
- the
doublevalue with the specified name - Throws:
jakarta.jms.JMSException- if the JMS provider fails to read the message due to some internal error.jakarta.jms.MessageFormatException- if this type conversion is invalid.
-
getString
Returns theStringvalue with the specified name.- Specified by:
getStringin interfacejakarta.jms.MapMessage- Parameters:
name- the name of theString- Returns:
- the
Stringvalue with the specified name; if there is no item by this name, a null value is returned - Throws:
jakarta.jms.JMSException- if the JMS provider fails to read the message due to some internal error.jakarta.jms.MessageFormatException- if this type conversion is invalid.
-
getBytes
Returns the byte array value with the specified name.- Specified by:
getBytesin interfacejakarta.jms.MapMessage- Parameters:
name- the name of the byte array- Returns:
- a copy of the byte array value with the specified name; if there is no item by this name, a null value is returned.
- Throws:
jakarta.jms.JMSException- if the JMS provider fails to read the message due to some internal error.jakarta.jms.MessageFormatException- if this type conversion is invalid.
-
getObject
Returns the value of the object with the specified name.This method can be used to return, in objectified format, an object in the Java programming language ("Java object") that had been stored in the Map with the equivalent
setObjectmethod call, or its equivalent primitiveset typemethod.Note that byte values are returned as
byte[], notByte[].- Specified by:
getObjectin interfacejakarta.jms.MapMessage- Parameters:
name- the name of the Java object- Returns:
- a copy of the Java object value with the specified name, in
objectified format (for example, if the object was set as an
int, anIntegeris returned); if there is no item by this name, a null value is returned - Throws:
jakarta.jms.JMSException- if the JMS provider fails to read the message due to some internal error.
-
getMapNames
Returns anEnumerationof all the names in theMapMessageobject.- Specified by:
getMapNamesin interfacejakarta.jms.MapMessage- Returns:
- an enumeration of all the names in this
MapMessage - Throws:
jakarta.jms.JMSException
-
put
- Throws:
jakarta.jms.JMSException
-
setBoolean
Sets abooleanvalue with the specified name into the Map.- Specified by:
setBooleanin interfacejakarta.jms.MapMessage- Parameters:
name- the name of thebooleanvalue- thebooleanvalue to set in the Map- Throws:
jakarta.jms.JMSException- if the JMS provider fails to write the message due to some internal error.IllegalArgumentException- if the name is null or if the name is an empty string.jakarta.jms.MessageNotWriteableException- if the message is in read-only mode.
-
setByte
Sets abytevalue with the specified name into the Map.- Specified by:
setBytein interfacejakarta.jms.MapMessage- Parameters:
name- the name of thebytevalue- thebytevalue to set in the Map- Throws:
jakarta.jms.JMSException- if the JMS provider fails to write the message due to some internal error.IllegalArgumentException- if the name is null or if the name is an empty string.jakarta.jms.MessageNotWriteableException- if the message is in read-only mode.
-
setShort
Sets ashortvalue with the specified name into the Map.- Specified by:
setShortin interfacejakarta.jms.MapMessage- Parameters:
name- the name of theshortvalue- theshortvalue to set in the Map- Throws:
jakarta.jms.JMSException- if the JMS provider fails to write the message due to some internal error.IllegalArgumentException- if the name is null or if the name is an empty string.jakarta.jms.MessageNotWriteableException- if the message is in read-only mode.
-
setChar
Sets a Unicode character value with the specified name into the Map.- Specified by:
setCharin interfacejakarta.jms.MapMessage- Parameters:
name- the name of the Unicode charactervalue- the Unicode character value to set in the Map- Throws:
jakarta.jms.JMSException- if the JMS provider fails to write the message due to some internal error.IllegalArgumentException- if the name is null or if the name is an empty string.jakarta.jms.MessageNotWriteableException- if the message is in read-only mode.
-
setInt
Sets anintvalue with the specified name into the Map.- Specified by:
setIntin interfacejakarta.jms.MapMessage- Parameters:
name- the name of theintvalue- theintvalue to set in the Map- Throws:
jakarta.jms.JMSException- if the JMS provider fails to write the message due to some internal error.IllegalArgumentException- if the name is null or if the name is an empty string.jakarta.jms.MessageNotWriteableException- if the message is in read-only mode.
-
setLong
Sets alongvalue with the specified name into the Map.- Specified by:
setLongin interfacejakarta.jms.MapMessage- Parameters:
name- the name of thelongvalue- thelongvalue to set in the Map- Throws:
jakarta.jms.JMSException- if the JMS provider fails to write the message due to some internal error.IllegalArgumentException- if the name is null or if the name is an empty string.jakarta.jms.MessageNotWriteableException- if the message is in read-only mode.
-
setFloat
Sets afloatvalue with the specified name into the Map.- Specified by:
setFloatin interfacejakarta.jms.MapMessage- Parameters:
name- the name of thefloatvalue- thefloatvalue to set in the Map- Throws:
jakarta.jms.JMSException- if the JMS provider fails to write the message due to some internal error.IllegalArgumentException- if the name is null or if the name is an empty string.jakarta.jms.MessageNotWriteableException- if the message is in read-only mode.
-
setDouble
Sets adoublevalue with the specified name into the Map.- Specified by:
setDoublein interfacejakarta.jms.MapMessage- Parameters:
name- the name of thedoublevalue- thedoublevalue to set in the Map- Throws:
jakarta.jms.JMSException- if the JMS provider fails to write the message due to some internal error.IllegalArgumentException- if the name is null or if the name is an empty string.jakarta.jms.MessageNotWriteableException- if the message is in read-only mode.
-
setString
Sets aStringvalue with the specified name into the Map.- Specified by:
setStringin interfacejakarta.jms.MapMessage- Parameters:
name- the name of theStringvalue- theStringvalue to set in the Map- Throws:
jakarta.jms.JMSException- if the JMS provider fails to write the message due to some internal error.IllegalArgumentException- if the name is null or if the name is an empty string.jakarta.jms.MessageNotWriteableException- if the message is in read-only mode.
-
setBytes
Sets a byte array value with the specified name into the Map.- Specified by:
setBytesin interfacejakarta.jms.MapMessage- Parameters:
name- the name of the byte arrayvalue- the byte array value to set in the Map; the array is copied so that the value fornamewill not be altered by future modifications- Throws:
jakarta.jms.JMSException- if the JMS provider fails to write the message due to some internal error.NullPointerException- if the name is null, or if the name is an empty string.jakarta.jms.MessageNotWriteableException- if the message is in read-only mode.
-
setBytes
public void setBytes(String name, byte[] value, int offset, int length) throws jakarta.jms.JMSException Sets a portion of the byte array value with the specified name into the Map.- Specified by:
setBytesin interfacejakarta.jms.MapMessage- Parameters:
name- the name of the byte arrayvalue- the byte array value to set in the Mapoffset- the initial offset within the byte arraylength- the number of bytes to use- Throws:
jakarta.jms.JMSException- if the JMS provider fails to write the message due to some internal error.IllegalArgumentException- if the name is null or if the name is an empty string.jakarta.jms.MessageNotWriteableException- if the message is in read-only mode.
-
setObject
Sets an object value with the specified name into the Map.This method works only for the objectified primitive object types (
Integer,Double,Long...),Stringobjects, and byte arrays.- Specified by:
setObjectin interfacejakarta.jms.MapMessage- Parameters:
name- the name of the Java objectvalue- the Java object value to set in the Map- Throws:
jakarta.jms.JMSException- if the JMS provider fails to write the message due to some internal error.IllegalArgumentException- if the name is null or if the name is an empty string.jakarta.jms.MessageFormatException- if the object is invalid.jakarta.jms.MessageNotWriteableException- if the message is in read-only mode.
-
itemExists
Indicates whether an item exists in thisMapMessageobject.- Specified by:
itemExistsin interfacejakarta.jms.MapMessage- Parameters:
name- the name of the item to test- Returns:
- true if the item exists
- Throws:
jakarta.jms.JMSException- if the JMS provider fails to determine if the item exists due to some internal error.
-
compress
- Overrides:
compressin classMessage- Throws:
IOException
-
toString
-
getContentMap
- Throws:
jakarta.jms.JMSException
-
isBodyAssignableTo
- Specified by:
isBodyAssignableToin interfacejakarta.jms.Message- Overrides:
isBodyAssignableToin classActiveMQMessage- Throws:
jakarta.jms.JMSException
-
doGetBody
- Overrides:
doGetBodyin classActiveMQMessage- Throws:
jakarta.jms.JMSException
-