从目标名称Apache Camel + IBM MQ中除去“ queue:///”

时间:2019-04-05 08:56:17

标签: apache-camel jms ibm-mq

使用apache骆驼,我将消息发送给IBM Queue Q001IN,但另一方面,应用程序正在验证目的地,他们期望目的地为Q001IN,但是他们作为队列接收:/ // Q001IN,而不是Q001IN。

...
.to("jms:Q001IN")
.end()

无论如何,我可以覆盖它以删除队列:///吗?

我在下面尝试过,但是不起作用。

.setHeader("destination", simple("QUEUE_NAME"))
.setHeader("destinationName", simple("QUEUE_NAME"))
.to("jms:Q001IN")

2 个答案:

答案 0 :(得分:1)

确切地说,您的接收方应用程序接收到JMS Destination对象JMS Queue。您看到的“ queue:///”是该对象的toString()。如果要获取队列名称,则必须(不幸地)必须将目标对象强制转换为javax.jms.Queue,然后使用方法Queue.getQueueName()。我不确定您的接收应用程序,但是说目标包含您收到的消息的JMSDestination:

import javax.jms.Queue
Queue q = (Queue)dest;
String qName = q.getQueueName();

答案 1 :(得分:0)

我认为其他应用程序正在使用IBM MQ特定API和标头。这就是他们只能检索队列名称的原因。如果我使用下面的方法发送消息,他们将能够接收没有队列的队列名称:///

    Hashtable<String, Object> properties = new Hashtable<String, Object>();
    properties.put(MQConstants.HOST_NAME_PROPERTY, HOST);
    properties.put(MQConstants.PORT_PROPERTY, new Integer(PORT));
    properties.put(MQConstants.CHANNEL_PROPERTY, CHANNEL);
    MQQueueManager queueManager = new MQQueueManager(QUEUE_MANAGER, properties);
    int openOptions = MQConstants.MQOO_INPUT_AS_Q_DEF | MQConstants.MQOO_OUTPUT;
    com.ibm.mq.MQQueue ibmQueue = queueManager.accessQueue(QUEUE_NAME, openOptions);
    MQMessage msg = new MQMessage();
    MQRFH2 rfh2 = new MQRFH2();
    rfh2.setFieldValue("mcd", "Msd", "jms_text");
    rfh2.setFieldValue("jms", "Dst", QUEUE_NAME);
    rfh2.write(msg);
    msg.writeString("This is using IBM API : " + System.currentTimeMillis() % 1000);
    msg.format = CMQC.MQFMT_RF_HEADER_2;
    MQPutMessageOptions pmo = new MQPutMessageOptions();
    ibmQueue.put(msg, pmo);

即使我使用如下的JMS API。

        JmsFactoryFactory ff = JmsFactoryFactory.getInstance(WMQConstants.WMQ_PROVIDER);
        JmsConnectionFactory cf = ff.createConnectionFactory();
        cf.setStringProperty(WMQConstants.WMQ_HOST_NAME, HOST);
        cf.setIntProperty(WMQConstants.WMQ_PORT, PORT);
        cf.setStringProperty(WMQConstants.WMQ_CHANNEL, CHANNEL);
        cf.setIntProperty(WMQConstants.WMQ_CONNECTION_MODE, WMQConstants.WMQ_CM_CLIENT);
        cf.setStringProperty(WMQConstants.WMQ_QUEUE_MANAGER, QUEUE_MANAGER);
        cf.setStringProperty(WMQConstants.WMQ_APPLICATIONNAME, "JmsPutGet (JMS)");
        cf.setBooleanProperty(WMQConstants.USER_AUTHENTICATION_MQCSP, true);
        cf.setStringProperty(WMQConstants.USERID, APP_USER);
        JMSContext context = cf.createContext();
        Queue destination = context.createQueue(QUEUE_NAME);

        TextMessage message = context.createTextMessage("This is using JMS API" + System.currentTimeMillis() % 1000);
        JMSProducer producer = context.createProducer();
        producer.send(destination, message);
        System.out.println("Sent message:\n" + message);
        System.out.println("JMSDestination : " + ((Queue) message.getJMSDestination()).getQueueName());

并尝试区分目的地队列并获取我正在获取的队列名称

queue:///<Queue_Name>

下面是输出

This is using JMS API456
JMSDestination : queue:///<Queue_Name>

当我尝试浏览使用jms发送的消息和使用ibm mq发送的其他消息

两者的目的地均不同,如下所示。

enter image description here