java oracle消息队列_如何使用Java将JMS消息排入Oracle AQ

只需复制粘贴此代码并尝试. (如果它适合你)然后仔细检查代码,并了解.

在执行时,

>首先取消注释main方法中的’createQueue()’行.

之后,

>注释并取消注释’sendMessage()’行并尝试发送您的消息.

然后分别评论/取消注释每一行并试一试.

import java.util.ArrayList;

import java.util.Enumeration;

import java.util.List;

import javax.jms.JMSException;

import javax.jms.MessageConsumer;

import javax.jms.MessageProducer;

import javax.jms.Queue;

import javax.jms.QueueBrowser;

import javax.jms.QueueConnection;

import javax.jms.QueueConnectionFactory;

import javax.jms.Session;

import javax.jms.TextMessage;

import oracle.AQ.AQQueueTable;

import oracle.AQ.AQQueueTableProperty;

import oracle.jms.AQjmsDestination;

import oracle.jms.AQjmsDestinationProperty;

import oracle.jms.AQjmsFactory;

import oracle.jms.AQjmsSession;

public class OracleAQClient {

public static QueueConnection getConnection() {

String hostname = "localhost";

String oracle_sid = "xe";

int portno = 1521;

String userName = "jmsuser";

String password = "jmsuser";

String driver = "thin";

QueueConnectionFactory QFac = null;

QueueConnection QCon = null;

try {

// get connection factory , not going through JNDI here

QFac = AQjmsFactory.getQueueConnectionFactory(hostname, oracle_sid, portno, driver);

// create connection

QCon = QFac.createQueueConnection(userName, password);

} catch (Exception e) {

e.printStackTrace();

}

return QCon;

}

public static void createQueue(String user, String qTable, String queueName) {

try {

/* Create Queue Tables */

System.out.println("Creating Queue Table...");

QueueConnection QCon = getConnection();

Session session = QCon.createQueueSession(false, Session.CLIENT_ACKNOWLEDGE);

AQQueueTableProperty qt_prop;

AQQueueTable q_table = null;

AQjmsDestinationProperty dest_prop;

Queue queue = null;

qt_prop = new AQQueueTableProperty("SYS.AQ$_JMS_TEXT_MESSAGE");

q_table = ((AQjmsSession) session).createQueueTable(user, qTable, qt_prop);

System.out.println("Qtable created");

dest_prop = new AQjmsDestinationProperty();

/* create a queue */

queue = ((AQjmsSession) session).createQueue(q_table, queueName, dest_prop);

System.out.println("Queue created");

/* start the queue */

((AQjmsDestination) queue).start(session, true, true);

} catch (Exception e) {

e.printStackTrace();

return;

}

}

public static void sendMessage(String user, String queueName,String message) {

try {

QueueConnection QCon = getConnection();

Session session = QCon.createQueueSession(false, Session.CLIENT_ACKNOWLEDGE);

QCon.start();

Queue queue = ((AQjmsSession) session).getQueue(user, queueName);

MessageProducer producer = session.createProducer(queue);

TextMessage tMsg = session.createTextMessage(message);

//set properties to msg since axis2 needs this parameters to find the operation

tMsg.setStringProperty("SOAPAction", "getQuote");

producer.send(tMsg);

System.out.println("Sent message = " + tMsg.getText());

session.close();

producer.close();

QCon.close();

} catch (JMSException e) {

e.printStackTrace();

return;

}

}

public static void browseMessage(String user, String queueName) {

Queue queue;

try {

QueueConnection QCon = getConnection();

Session session = QCon.createQueueSession(false, Session.CLIENT_ACKNOWLEDGE);

QCon.start();

queue = ((AQjmsSession) session).getQueue(user, queueName);

QueueBrowser browser = session.createBrowser(queue);

Enumeration enu = browser.getEnumeration();

List list = new ArrayList();

while (enu.hasMoreElements()) {

TextMessage message = (TextMessage) enu.nextElement();

list.add(message.getText());

}

for (int i = 0; i < list.size(); i++) {

System.out.println("Browsed msg " + list.get(i));

}

browser.close();

session.close();

QCon.close();

} catch (JMSException e) {

e.printStackTrace();

}

}

public static void consumeMessage(String user, String queueName) {

Queue queue;

try {

QueueConnection QCon = getConnection();

Session session = QCon.createQueueSession(false, Session.CLIENT_ACKNOWLEDGE);

QCon.start();

queue = ((AQjmsSession) session).getQueue(user, queueName);

MessageConsumer consumer = session.createConsumer(queue);

TextMessage msg = (TextMessage) consumer.receive();

System.out.println("MESSAGE RECEIVED " + msg.getText());

consumer.close();

session.close();

QCon.close();

} catch (JMSException e) {

e.printStackTrace();

}

}

public static void main(String args[]) {

String userName = "jmsuser";

String queue = "sample_aq";

String qTable = "sample_aqtbl";

//createQueue(userName, qTable, queue);

//sendMessage(userName, queue,"text");

//browseMessage(userName, queue);

//consumeMessage(userName, queue);

}

}

您需要从oracle DB安装目录将这些jar / libs复制到java项目中

> ojdbc6.jar

> jta.jar

> jmscommon.jar

> aqapi.jar

这篇文章应归功于Ratha [1].很少有东西要修改,我只修改了那些并提供了代码.

谢谢

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值