【发布时间】:2016-08-31 20:34:08
【问题描述】:
消息以 xml 格式进入队列,其中包含标签 a。 我必须阅读这个标签,这样我的听众就不会选择那些包含 a、b 或 c 的destinationInstance 的消息。
Xml 如下:
<?xml version="1.0"?>
-<Envelope>
-<Header version="2.0">
<senderInstance>asas</senderInstance>
<destination>asassd</destination>
<destinationInstance>a</destinationInstance>
<correlationId>94825641</correlationId>
</Header>
-<Envelope>
Java 代码:
public void listenMessage(final String qLookUpName,final JMSClientFactory jmsClientFactory, int noOfListeners) {
Queue queue = null;
QueueReceiver[] receiver = new QueueReceiver[noOfListeners + 1];
Message message = null;
queue = queueMap.get(qLookUpName);
tracer.info("Queue name - " + queue);
try {
if (null == queue) {
InitialContext ctx = new InitialContext(ldapProps);
queue = (javax.jms.Queue) ctx.lookup(qLookUpName);
queueMap.put(qLookUpName, queue);
}
logger.info("Entered listenJMSMessage()");
for (int receiverCnt = 0; receiverCnt < noOfListeners; receiverCnt++) {
try {
logger.debug("queuename : " + queue.getQueueName());
tracer.info("queuename : " + queue.getQueueName());
receiver[receiverCnt] = session.createReceiver(queue);
tracer.info("receiver : " + receiver);
logger.debug("Listening for Messages");
receiver[receiverCnt].setMessageListener(new MessageListener(){
JMSClientFactory clientFactory= jmsClientFactory;
Document xmlDocument;
public void onMessage(Message arg0) {
try {
logger.debug("got message "+ arg0.getJMSCorrelationID());
logger.debug("Received message from the queue :"
+ arg0.getJMSCorrelationID()+" On Listener :" + this);
String xmlResponse=((TextMessage)arg0).getText();
xmlDocument = DocumentBuilderFactory.newInstance()
.newDocumentBuilder().parse(new InputSource(new StringReader(xmlResponse)));
String destinationInstance=xmlDocument.getElementsByTagName("destinationInstance").item(0).getTextContent();
logger.debug(" destinationInstance: " + destinationInstance);
if(destinationInstance.equalsIgnoreCase("a") || destinationInstance.equalsIgnoreCase("b") ||
destinationInstance.equalsIgnoreCase("c")){
logger.debug("Calling process(arg0) method.");
clientFactory.process(arg0);
}
} catch (JMSException e) {
logger.error("Exception - " , e);
// TODO Auto-generated catch block
//e.printStackTrace();
} catch (Exception e) {
logger.error("Exception - " , e);
} catch(Throwable t) {
logger.error("Error while dequeuing -", t);
} finally {
NDC.remove();
}
}
});
} catch (JMSException e) {
logger.debug("stack trace -" ,e);
}
}
} catch (NamingException e) {
logger.debug("NamingException stack trace -" ,e);
}
logger.debug("Listening for another message");
}
【问题讨论】:
-
您使用什么 JMS 提供程序?