八宝书库 > 文学其他电子书 > JMS简明教程(PDF格式) >

第15部分

JMS简明教程(PDF格式)-第15部分

小说: JMS简明教程(PDF格式) 字数: 每页4000字

按键盘上方向键 ← 或 → 可快速上下翻页,按键盘上的 Enter 键可回到本书目录页,按键盘上方向键 ↑ 可回到本页顶部!
————未阅读完?加入书签已便下次继续阅读!




  


…………………………………………………………Page 55……………………………………………………………

                                               



        XAConnection               XAQueueConnection               XATopicConnection  



          XASession                  XAQueueSession                 XATopicSession  



                                                                             



9  JMS 样例代码  



     本章给出了一些展示JMS 客户端如何使用JMS API 的代码样例。也解释了如何使用几个 

消息类型。这些例子使用了支持统一消息模型的方法:这些例子使用点对点或发布/订阅进 

行工作。用JMS API 进行工作是推荐的方式。  

     在JMS 规范的早期版本中,只支持消息域(点对点或发布/订阅)各自的接口,且客户 

端要么使用点对点要么使用发布/订阅来进行编程。现在,JMS 客户端可以使用JMS 公共接 

口进行编程。  

     在例子中,客户端应用发送和接收股票报价信息。客户端应用从股票报价服务中接收消 

息。股票报价服务在这个例子中没有描述。  

     为了简化这个例子,没有对异常进行处理。  

     本章描述了为发送和接收消息而创建正确环境的步骤。  

     在描述了基本的功能后,本章描述如何执行一些其他的公共功能,例如使用消息选择器。  



9。1  准备发送和接收消息  



     下面是建立连接然后准备发送和接收消息的基本步骤。  

     z   获得ConnectionFactory 和Destination。  

     z   创建Connection 和Session 。  

     z   创建MessageConsumer。  

     z   创建MessageProducer。  



9。1。1 获取ConnectionFactory  



     消息生产者和消息消费者(发送者和接收者)都需要得到ConnectionFactory,并使用它 

来建立Connection 和Session 。  

     通常,管理员已经为JMS 客户端创建和配置好了ConnectionFactory 。客户端程序通常使 

用JNDI API 来查找ConnectionFactory 。  

     import javax。naming。*;  

     import javax。jms。*;  

     ConnectionFactory connectionFactory;  

     Context messaging = new InitialContext();  

     connectionFactory = (ConnectionFactory)   

          messaging。lookup(〃ConnectionFactory〃);  



                                                                                    55 / 66  

  


…………………………………………………………Page 56……………………………………………………………

                                                   



9。1。2 获取Destination  



     管理员已经创建和配置了一个名字为“StockQueue ”的Queue,它是股票报价消息被发 

送和接收的地方。同样,可以使用JNDI API 来查找目的地。  

     Queue stockQueue;  

     stockQueue = (Queue)messaging。lookup(〃StockSource〃);  



9。1。3 创建Connection  



     在得到ConnectionFactory 之后,客户端程序使用它来创建Connection 。  

     Connection connection;  

     connection = ConnectionFactory。createConnection();  



9。1。4 创建Session  



     在得到 Connection        之后,客户端程序使用它来创建 Session 。这个 Session                           用于创建 

MessageProducer  (发送消息)或MessageConuser  (接收消息)。  

     Connection。createSession 方法有两个参数:  

     z    一个表示会话是否是事务性的布尔。  

     z    消息确认模式。  

     Session session;  

     /* Session is not transacted;   

     *   uses AUTO_ACKNOWLEDGE for message  

     *  acknowledgement  

     */  

     session = connection。createSession(false; Session。AUTO_ACKNOWLEDGE);  



9。1。5 创建MessageProducer  



     在得到 Session        后,客户端程序使用 Session                    来创建 MessageProducer 。这个 

MessageProducer 对象用于向目的地发送消息。通过使用Session。createProducer 方法来创建 

MessageProducer,参数是消息被发送的目的地。  

     MessageProducer sender;  

     /* Value in stockQueue previously looked up in the JNDI  

     *  createProducer takes a Destination  

     */  

     sender = session。createProducer(stockQueue);  



9。1。6 创建MessageConsumer  



     消息可以被同步或异步的消费。这个例子展示了如何创建同步消费消息的消息消费者。 



                                                                                            56 / 66  

  


…………………………………………………………Page 57……………………………………………………………

                                                



参见9。3。1  “异步接收消息”了解如何异步消费消息。  

     MessageConsumer    用于从目的地接收消息,在这个例子中是“StockQueue ”。用 

Session。createConsumer 方法来创建MessageConsumer,参数是接收消息的目的地。  

     MessageConsumer receiver;  

     /* Value in stockQueue previously looked up in the JNDI  

     *  createConsumer takes a Destination  

     */  

     receiver = session。createConsumer(stockQueue);  



9。1。7 启动消息转发  



     到现在为止,消息的转发还是被禁止的,以便前面的设置不会被异步转发的消息打断。 

现在设置已经完成,可以告诉Connection 开始向MessageConsumer 转发消息了。  

     connection。start();  



9。1。8 使用TextMessage  



     有几个消息格式。在这个例子中,股票报价消息作为文本串被发送。客户端按文本串读 

取和展示这个消息。  

     下面的代码解释了如何创建这样的消息:  

     String        stockData;    /* Stock information as a string */  

     TextMessage   message;  

     /* Set the message’s text to be the stockData string */  

     message = session。createTextMessage();  

     message。setText(stockData);  



9。2  发送和接收消息  



     现在已经完成了Session 的设置,你可以发送和接收消息了。本节描述了如何:  

     z   创建消息  

     z    发送消息  

     z    同步接收消息  



9。2。1 发送消息  



     为了发送消息,使用MessageProducer。send 方法,参数是Message 对象。  

     /* Send the message */  

     sender。send(message);  



                                                                                       57 / 66  

  


…………………………………………………………Page 58……………………………………………………………

                                                     



9。2。2 同步接收消息  



     为了接收Queue 里的消息,你可以使用MessageConsumer。receive 方法。这个方法调用 

在消息到达Queue 之前可能阻塞。这个方法也可以用于从Topic  中接收消息。  

     TextMessage stockMessage;  

     stockMessage = (TextMessage)receiver。receive();  

     为了限制客户端阻塞的时间长度,使用 receive 方法的超时参数。如果在超时到期时还 

没有消息到达,那么receive 方法返回。超时参数按毫秒计时。  

     TextMessage stockMessage;  

     /* Wait 4 seconds for a message */  

     TextMessage = (TextMessage)receiver。receive(4000);  



9。2。3 解包TextMessage  



     股票报价信息使用 TextMessage                      发送。为了从消息中得到这个信息,使用 

TextMessage。getText 方法。它以字符串返回消息的内容。  

     String newStockData;    /* Stock information as a string */  

     newStockData = message。getText();  



9。3  其他消息特性  



     本节不仅提供了基本的消息功能,而且还描述了如何执行某些其他的公共消息功能:  

     z    创建异步MessageListener。  

     z    使用消息选择器过滤消息转发。  

     z    创建Topic 的永久订阅。  

     z    对使用永久订阅的Topic 进行重新连接。  



9。3。1 异步接收消息  



     为了在消息被转发到消息消费者时异步的接收消息,客户端程序需要创建实现了 

MessageListener     接口的消息监听器。本例中 MessageListener                               接口的实现称为 

StockListener。java,类似于下面的代码:  

     import javax。jms。*;  

     public class StockListener implements MessageListener   

     {  

     public void onMessage(Message message) {  

      /* Unpack and handle the messages received */  

     。。。  

     }  

       }  

     客户端程序按下面的方式将这个MessageListener 对象注册到MessageConsumer 对象:  



                                                                                               58 / 66  

  


…………………………………………………………Page 59……………………………………………………………

                                                         



      StockListener myListener = new StockListener();  

      /* Receiver is MessageConsumer object */  

      receiver。setMessageListener(myListener);  

      Connection  必须被启动以迎接开始的消息转发。当消息被发布到 Queue  时会异步的通 

知MessageListener。这通过MessageListener 接口的onMessage 方法实现。由客户端负责处 

理消息。  

      public void onMessage(Message message)   

      {  

      String newStockData;  

      /* Unpack and handle the messages received */  

      newStockData = message。getText();  

      if(。。。)  

      {  

       /* Logic related to the data */  

      }  

      }  



9。3。2 使用消息选择器  



      在这个例子中,客户端程序只对技术相关的股票感兴趣。消息的发送者向消息的属性中 

设置一个称为StockSector 的属性。它的值包括“Technology ”,“Financial”,“Manufacturing”; 

 “Emerging”和“Global ”。消息发送者通过使用Message。setStringProperty 方法来设置这些 

属性值。  

      String stockData;    /* Stock information as a String */  

      TextMessage message;  

      /* Set the message’s text to be the stockData string *  

      message = session。createTextMessage();  

      message。setText(stockData);  

      /* Set the message property ‘StockSector’  

      message。setStringProperty(〃StockSector〃; 〃Technology〃);  

      当接收股票报价消息客户端程序 MessageConsumer 被创建时,它可以创建一个消息选 

择器字符串来决定它将接收哪些消息。  

      String selector;  

      selector = new String(〃(StockSector = ‘Technology’)〃  

      这个字符串在创建MessageConsumer 时指定。  

      MessageConsumer receiver;  

      receiver = session。createConsumer(stockQueue; selector);  

      客户端程序只接收和Technology 相关的消息。  



9。3。3 使用永久订阅  



      永久订阅用于从Topic 接收消息。当JMS  客户端创建永久订阅时,客户端能够从Topic 

断开连接。当客户端程序重新连接时,它可以收到断开连接后到达的消息。在这个例子中, 



                                                                                                      59 / 66  

  


…………………………………………………………Page 60……………………………………………………………

                                                



Destination 提供对消息更新的通知。  



9。3。3。1 创建永久订阅  



     下面的例子创建了从Topic 获取消息的永久订阅。首先,客户端程序必须执行常规的设 

置步骤,查找ConnectionFactory 和Destination,创建Connection 和Session,如节9。1 “准备 

发送和接收消息”中所述。  

     impo

返回目录 上一页 下一页 回到顶部 0 0

你可能喜欢的