- java.lang.Object
-
- jakarta.jms.TopicRequestor
-
public class TopicRequestor extends Object
TheTopicRequestorhelper class simplifies making service requests.The
TopicRequestorconstructor is given a non-transactedTopicSessionand a destinationTopic. It creates aTemporaryTopicfor the responses and provides arequestmethod that sends the request message and waits for its reply.This is a very basic request/reply abstraction which assumes the session is non-transacted with a delivery mode of either AUTO_ACKNOWLEDGE or DUPS_OK_ACKNOWLEDGE. It is expected that most applications will create less basic implementations.
- Since:
- JMS 1.0
- Version:
- Jakarta Messaging 2.0
- See Also:
QueueRequestor
-
-
Constructor Summary
Constructors Constructor Description TopicRequestor(TopicSession session, Topic topic)Constructor for theTopicRequestorclass.
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description voidclose()Closes theTopicRequestorand its session.Messagerequest(Message message)Sends a request and waits for a reply.
-
-
-
Constructor Detail
-
TopicRequestor
public TopicRequestor(TopicSession session, Topic topic) throws JMSException
Constructor for theTopicRequestorclass.This implementation assumes the session parameter to be non-transacted, with a delivery mode of either
AUTO_ACKNOWLEDGEorDUPS_OK_ACKNOWLEDGE.- Parameters:
session- theTopicSessionthe topic belongs totopic- the topic to perform the request/reply call on- Throws:
JMSException- if the Jakarta Messaging provider fails to create theTopicRequestordue to some internal error.InvalidDestinationException- if an invalid topic is specified.
-
-
Method Detail
-
request
public Message request(Message message) throws JMSException
Sends a request and waits for a reply. The temporary topic is used for theJMSReplyTodestination; the first reply is returned, and any following replies are discarded.- Parameters:
message- the message to send- Returns:
- the reply message
- Throws:
JMSException- if the Jakarta Messaging provider fails to complete the request due to some internal error.
-
close
public void close() throws JMSExceptionCloses theTopicRequestorand its session.Since a provider may allocate some resources on behalf of a
TopicRequestoroutside the Java virtual machine, clients should close them when they are not needed. Relying on garbage collection to eventually reclaim these resources may not be timely enough.Note that this method closes the
TopicSessionobject passed to theTopicRequestorconstructor.- Throws:
JMSException- if the Jakarta Messaging provider fails to close theTopicRequestordue to some internal error.
-
-