javax.jms

Interface TopicPublisher

  • All Superinterfaces:
    AutoCloseable, MessageProducer

    public interface TopicPublisher
    extends MessageProducer
    A client uses a TopicPublisher object to publish messages on a topic. A TopicPublisher object is the publish-subscribe form of a message producer.

    Normally, the Topic is specified when a TopicPublisher is created. In this case, an attempt to use the publish methods for an unidentified TopicPublisher will throw a java.lang.UnsupportedOperationException.

    If the TopicPublisher is created with an unidentified Topic, an attempt to use the publish methods that assume that the Topic has been identified will throw a java.lang.UnsupportedOperationException.

    During the execution of its publish method, a message must not be changed by other threads within the client. If the message is modified, the result of the publish is 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, JMSMessageID and JMSTimeStamp. When the message is published, the values of these headers are ignored. After completion of the publish, the headers hold the values specified by the method publishing the message. It is possible for the publish method not to set JMSMessageID and JMSTimeStamp if the setting of these headers is explicitly disabled by the MessageProducer.setDisableMessageID or MessageProducer.setDisableMessageTimestamp method.

    Creating a MessageProducer provides the same features as creating a TopicPublisher. A MessageProducer object is recommended when creating new code. The TopicPublisher is provided to support existing code.

    Because TopicPublisher inherits from MessageProducer, it inherits the send methods that are a part of the MessageProducer interface. Using the send methods will have the same effect as using the publish methods: they are functionally the same.

    Since:
    JMS 1.0
    Version:
    JMS 2.0
    See Also:
    Session.createProducer(Destination), TopicSession.createPublisher(Topic)
    • Method Detail

      • getTopic

        Topic getTopic()
                throws JMSException
        Gets the topic associated with this TopicPublisher.
        Returns:
        this publisher's topic
        Throws:
        JMSException - if the JMS provider fails to get the topic for this TopicPublisher due to some internal error.
      • publish

        void 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 JMS 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 TopicPublisher with an invalid topic.
        UnsupportedOperationException - if a client uses this method with a TopicPublisher that did not specify a topic at creation time.
      • publish

        void 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 JMS 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 JMS 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.

Traduction non disponible

Les API Java ne sont pas encore traduites en français sur l'infobrol. Seule la version anglaise est disponible pour l'instant.

Version en cache

22/08/2025 05:31:53 Cette version de la page est en cache (à la date du 22/08/2025 05:31:53) afin d'accélérer le traitement.
Vous pouvez activer le mode utilisateur dans le menu en haut pour afficher la version plus récente de la page.

Document créé le 14/04/2008, dernière modification le 18/08/2025
Source du document imprimé : https://www.gaudry.be/java-api-javaee-rf-javax/jms/topicpublisher.html

L'infobrol est un site personnel dont le contenu n'engage que moi. Le texte est mis à disposition sous licence CreativeCommons(BY-NC-SA). Plus d'info sur les conditions d'utilisation et sur l'auteur.

Références

  1. Consulter le document html Langue du document :fr Manuel PHP : https://docs.oracle.com, TopicPublisher (Java(TM) EE 7 Specification APIs)

Ces références et liens indiquent des documents consultés lors de la rédaction de cette page, ou qui peuvent apporter un complément d'information, mais les auteurs de ces sources ne peuvent être tenus responsables du contenu de cette page.
L'auteur de ce site est seul responsable de la manière dont sont présentés ici les différents concepts, et des libertés qui sont prises avec les ouvrages de référence. N'oubliez pas que vous devez croiser les informations de sources multiples afin de diminuer les risques d'erreurs.