
概述
浏览只是针对Queue的概念,Topic没有浏览。浏览是指获取消息而消息依然保持在broker中,而消息的接收会把消息从broker中移除。
浏览可以用来实现对Queue中消息的监控。
JMS API
浏览的概念来源于JMS,所以有必要先把JmsTemplate放一放。先看一下下面的API:
Interface javax.jms.Session |
|
Interface javax.jms.QueueBrowser |
|
根据上面的API,我们应该可以这样使用:
QueueBrowser browser = session.createBrowser(queue);
Enumeration<Message> msgEnum = browser.getEnumeration();
browser.close(); while (msgEnum.hasMoreElements()) {
Message msg = msgEnum.nextElement();
}
P.S.只是推论,没有验证。
JmsTemplate的API
JmsTemplate提供了2组*3,共计6个浏览的方法。
- 基本的浏览
- 带有选择器的浏览
鉴于我们对这种分组的习惯、消息选择器的概念都已经驾轻就熟,所以这里不再分开介绍。我们一鼓作气,解决掉吧:
Class org.springframework.jms.core.JmsTemplate |
|
Interface org.springframework.jms.core.BrowserCallback<T> |
|
让我们先看下BrowserCallback定义的回调方法。我们在客户端和broker建立连接的整个过程中,截取这样的一段:
我们已经使用Session创建了QueueBrowser的实例,然后我们像前文的demo中那样浏览消息。我们决定对消息再做一下转换,比如如果能确定每一个消息的内容都是一个字符串,我们可以最终转换成java.util.List<String>类型的结果。
这个片段是我们浏览Queue的整个片段,这个片段也是BrowserCallback唯一关心的问题,我们定义了这个片段的具体实现,然后交给JmsTemplate,由它在合适的时候,按照我们定义的方式浏览并返回消息。
下面给个demo:
List<String> contList = jt.browse(DESTINATION_NAME,
new BrowserCallback<List<String>>() { public List<String> doInJms(Session session,
QueueBrowser browser) throws JMSException { MessageConverter converter = new SimpleMessageConverter();
List<String> messContentList = new ArrayList<String>(); @SuppressWarnings("unchecked")
Enumeration<Message> messageEnum = browser
.getEnumeration();
while (messageEnum.hasMoreElements()) {
Message msg = messageEnum.nextElement();
String text = (String) converter.fromMessage(msg);
messContentList.add(text);
}
return messContentList;
}
}); for (String text : contList) {
System.out.println(text);
}
注意:我们在15行使用了转换的类,转换的概念我们已经在08. Spring-JmsTemplate之发送中介绍过了。