Interface TopicPublisher
- 
- All Superinterfaces:
- java.lang.AutoCloseable,- MessageProducer
 
 public interface TopicPublisher extends MessageProducer A client uses aTopicPublisherobject to publish messages on a topic. ATopicPublisherobject is the publish-subscribe form of a message producer.Normally, the Topicis specified when aTopicPublisheris created. In this case, an attempt to use thepublishmethods for an unidentifiedTopicPublisherwill throw ajava.lang.UnsupportedOperationException.If the TopicPublisheris created with an unidentifiedTopic, an attempt to use thepublishmethods that assume that theTopichas been identified will throw ajava.lang.UnsupportedOperationException.During the execution of its publishmethod, a message must not be changed by other threads within the client. If the message is modified, the result of thepublishis undefined.After publishing a message, a client may retain and modify it without affecting the message that has been published. The same message object may be published multiple times. The following message headers are set as part of publishing a message: JMSDestination,JMSDeliveryMode,JMSExpiration,JMSPriority,JMSMessageIDandJMSTimeStamp. When the message is published, the values of these headers are ignored. After completion of thepublish, the headers hold the values specified by the method publishing the message. It is possible for thepublishmethod not to setJMSMessageIDandJMSTimeStampif the setting of these headers is explicitly disabled by theMessageProducer.setDisableMessageIDorMessageProducer.setDisableMessageTimestampmethod.Creating a MessageProducerprovides the same features as creating aTopicPublisher. AMessageProducerobject is recommended when creating new code. TheTopicPublisheris provided to support existing code.Because TopicPublisherinherits fromMessageProducer, it inherits thesendmethods that are a part of theMessageProducerinterface. Using thesendmethods will have the same effect as using thepublishmethods: they are functionally the same.- Since:
- JMS 1.0
- See Also:
- Session.createProducer(Destination),- TopicSession.createPublisher(Topic)
 
- 
- 
Method SummaryAll Methods Instance Methods Abstract Methods Modifier and Type Method Description TopicgetTopic()Gets the topic associated with thisTopicPublisher.voidpublish(Message message)Publishes a message to the topic.voidpublish(Message message, int deliveryMode, int priority, long timeToLive)Publishes a message to the topic, specifying delivery mode, priority, and time to live.voidpublish(Topic topic, Message message)Publishes a message to a topic for an unidentified message producer.voidpublish(Topic topic, Message message, int deliveryMode, int priority, long timeToLive)Publishes a message to a topic for an unidentified message producer, specifying delivery mode, priority and time to live.- 
Methods inherited from interface javax.jms.MessageProducerclose, getDeliveryDelay, getDeliveryMode, getDestination, getDisableMessageID, getDisableMessageTimestamp, getPriority, getTimeToLive, send, send, send, send, send, send, send, send, setDeliveryDelay, setDeliveryMode, setDisableMessageID, setDisableMessageTimestamp, setPriority, setTimeToLive
 
- 
 
- 
- 
- 
Method Detail- 
getTopicTopic getTopic() throws JMSException Gets the topic associated with thisTopicPublisher.- Returns:
- this publisher's topic
- Throws:
- JMSException- if the Jakarta Messaging provider fails to get the topic for this- TopicPublisherdue to some internal error.
 
 - 
publishvoid publish(Message message) throws JMSException Publishes a message to the topic. Uses theTopicPublisher's default delivery mode, priority, and time to live.- Parameters:
- message- the message to publish
- Throws:
- JMSException- if the Jakarta Messaging provider fails to publish the message due to some internal error.
- MessageFormatException- if an invalid message is specified.
- InvalidDestinationException- if a client uses this method with a- TopicPublisherwith an invalid topic.
- java.lang.UnsupportedOperationException- if a client uses this method with a- TopicPublisherthat did not specify a topic at creation time.
- See Also:
- MessageProducer.getDeliveryMode(),- MessageProducer.getTimeToLive(),- MessageProducer.getPriority()
 
 - 
publishvoid publish(Message message, int deliveryMode, int priority, long timeToLive) throws JMSException Publishes a message to the topic, specifying delivery mode, priority, and time to live.- Parameters:
- message- the message to publish
- deliveryMode- the delivery mode to use
- priority- the priority for this message
- timeToLive- the message's lifetime (in milliseconds)
- Throws:
- JMSException- if the Jakarta Messaging provider fails to publish the message due to some internal error.
- MessageFormatException- if an invalid message is specified.
- InvalidDestinationException- if a client uses this method with a- TopicPublisherwith an invalid topic.
- java.lang.UnsupportedOperationException- if a client uses this method with a- TopicPublisherthat did not specify a topic at creation time.
 
 - 
publishvoid publish(Topic topic, Message message) throws JMSException Publishes a message to a topic for an unidentified message producer. Uses theTopicPublisher's default delivery mode, priority, and time to live.Typically, a message producer is assigned a topic at creation time; however, the Jakarta Messaging API also supports unidentified message producers, which require that the topic be supplied every time a message is published. - Parameters:
- topic- the topic to publish this message to
- message- the message to publish
- Throws:
- JMSException- if the Jakarta Messaging provider fails to publish the message due to some internal error.
- MessageFormatException- if an invalid message is specified.
- InvalidDestinationException- if a client uses this method with an invalid topic.
- See Also:
- MessageProducer.getDeliveryMode(),- MessageProducer.getTimeToLive(),- MessageProducer.getPriority()
 
 - 
publishvoid publish(Topic topic, Message message, int deliveryMode, int priority, long timeToLive) throws JMSException Publishes a message to a topic for an unidentified message producer, specifying delivery mode, priority and time to live.Typically, a message producer is assigned a topic at creation time; however, the Jakarta Messaging API also supports unidentified message producers, which require that the topic be supplied every time a message is published. - Parameters:
- topic- the topic to publish this message to
- message- the message to publish
- deliveryMode- the delivery mode to use
- priority- the priority for this message
- timeToLive- the message's lifetime (in milliseconds)
- Throws:
- JMSException- if the Jakarta Messaging provider fails to publish the message due to some internal error.
- MessageFormatException- if an invalid message is specified.
- InvalidDestinationException- if a client uses this method with an invalid topic.
 
 
- 
 
-