簡體   English   中英

從目標名稱Apache Camel + IBM MQ中除去“ queue:///”

[英]Remove “queue:///” from destination name Apache Camel + IBM MQ

我使用apache駱駝將消息發送給IBM Queue Q001IN ,但是在另一端,應用程序正在為目的地進行驗證,他們期望目的地為Q001IN但是他們以queue:/// Q001IN而不是Q001IN的形式接收。

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

無論如何,我可以覆蓋它以刪除queue:///嗎?

我在下面嘗試過,但是沒有用。

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

確切地說,您的接收方應用程序會收到一個JMS目標對象JMS Queue 您看到的“ queue:///”是該對象的toString()。 如果要獲取隊列名稱,則必須(不幸地)必須將目標對象轉換為javax.jms.Queue ,然后使用方法Queue.getQueueName() 我不確定您的接收應用程序,但可以說dest包含您接收到的消息的JMSDestination:

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

我認為其他應用程序正在使用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發送的其他消息時

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

在此處輸入圖片說明

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM