package com.umessage.smscenter.sms.test;
import javax.jms.MessageListener;
import javax.naming.Context;
import javax.naming.InitialContext;
import javax.jms.TopicConnectionFactory;
import javax.jms.TopicConnection;
import javax.jms.TopicSession;
import javax.jms.TopicPublisher;
import javax.jms.TopicSubscriber;
import javax.jms.Topic;
import java.util.Properties;
import java.io.Serializable;
import javax.jms.Message;
/**
<p>Title:JMS Demo</p>
<p>Description:JMS PTP方式发布和接受消息</p>
<p>Copyright: Copyright (c) 2007</p>
<p>Company: Umessage</p>
<p>@author xiaobian</p>
<p>@version 1.0</p>
* Use this class to publish and subscribe messages.
*
* To send a text message:
* <code>
* JMSpublicTest jMSpublicTest = new JMSpublicTest();
* jMSpublicTest.publishText("Hello world");
* jMSpublicTest.close(); //Release resources
* </code>
*
* To receive a message:
* <code>0
* JMSpublicTest jMSpublicTest = new JMSpublicTest();
* jMSpublicTest.getTopicSubscriber();
* </code>
*/
public class JMSpublicTest implements MessageListener {
//定义上下文环境
private static Context context;
//定义事务
private boolean transacted = false;
//定义接收消息的模式
private int acknowledgementMode = javax.jms.Session.AUTO_ACKNOWLEDGE;
//定义主题连接工厂
private TopicConnectionFactory topicConnectionFactory;
//定义主题连接
private TopicConnection topicConnection;
//定义主题会话
private TopicSession topicSession;
//定义主题发布者
private TopicPublisher topicPublisher;
//定义主题的接收者
private TopicSubscriber topicSubscriber;
//定义主题消息
private Topic topic;
//定义主题连接工厂名称(服务器中配置的JNDI名称)
private String topicConnectionFactoryName = "smsConnectionFactory";
//定义主题发布者(JNDI名称)
private String publishTopicName = "SendTopic";
//定义主题接收者(JNDI名称)
private String subscribeTopicName = "ReceiveTopic";
//客户端ID ?
private String clientId = "";
//定义持久名称
private String durableName = "";
//是否持久化
private boolean durable = false;
public void setTransacted(boolean transacted) {
this.transacted = transacted;
}
//获得主题接受者并打开连接
public TopicSubscriber getTopicSubscriber() throws Exception {
if (topicSubscriber == null) {
if (isDurable()) {
topicSubscriber = getTopicSession(true).createDurableSubscriber(getSubscribeTopic(), getDurableName());
}
else {
topicSubscriber = getTopicSession(true).createSubscriber(getSubscribeTopic());
}
topicSubscriber.setMessageListener(this);
getTopicConnection(true).start();
}
return topicSubscriber;
}
//根据主题的JNDI名称获得订阅主题
public Topic getSubscribeTopic() throws Exception {
if (topic == null) {
Object obj = getContext().lookup(subscribeTopicName);
topic = (Topic) obj;
}
return topic;
}
//获得主题的发布者
public TopicPublisher getTopicPublisher() throws Exception {
if (topicPublisher == null) {
topicPublisher = getTopicSession(false).createPublisher(getPublishTopic());
}
return topicPublisher;
}
//根据主题的JNDI名称获得发布主题
public Topic getPublishTopic() throws Exception {
if (topic == null) {
Object obj = getContext().lookup(publishTopicName);
topic = (Topic) obj;
}
return topic;
}
//获得主题会话
public TopicSession getTopicSession(boolean consumer) throws Exception {
if (topicSession == null) {
topicSession = getTopicConnection(consumer).createTopicSession(isTransacted(), getAcknowledgementMode());
}
return topicSession;
}
//获得主题会话
public TopicConnection getTopicConnection(boolean consumer) throws Exception {
if (topicConnection == null) {
topicConnection = getTopicConnectionFactory().createTopicConnection();
if (isDurable() && consumer) {
topicConnection.setClientID(clientId);
}
topicConnection.start();
}
return topicConnection;
}
//获得主题的连接工厂
public TopicConnectionFactory getTopicConnectionFactory() throws Exception {
if (topicConnectionFactory == null) {
Object obj = getContext().lookup(topicConnectionFactoryName);
System.out.println("topicConnectionFactory=="+obj);
topicConnectionFactory = (TopicConnectionFactory) obj;
}
return topicConnectionFactory;
}
public void setDurable(boolean durable) {
this.durable = durable;
}
public boolean isDurable() {
return durable;
}
public void setDurableName(String durableName) {
this.durableName = durableName;
}
public String getDurableName() {
return durableName;
}
public void setClientId(String clientId) {
this.clientId = clientId;
}
public String getClientId() {
return clientId;
}
public void setSubscribeTopicName(String subscribeTopicName) {
this.subscribeTopicName = subscribeTopicName;
}
public String getSubscribeTopicName() {
return subscribeTopicName;
}
public void setPublishTopicName(String publishTopicName) {
this.publishTopicName = publishTopicName;
}
public String getPublishTopicName() {
return publishTopicName;
}
public void setTopicConnectionFactoryName(String topicConnectionFactoryName) {
this.topicConnectionFactoryName = topicConnectionFactoryName;
}
public String getTopicConnectionFactoryName() {
return topicConnectionFactoryName;
}
public void setAcknowledgementMode(int acknowledgementMode) {
this.acknowledgementMode = acknowledgementMode;
}
public int getAcknowledgementMode() {
return acknowledgementMode;
}
public boolean isTransacted() {
return transacted;
}
//获得应用服务器上下文
public Context getInitialContext() throws Exception {
String url = "t3://127.0.0.1:7001";
String user = "xiaobian";
String password = "12345678";
Properties properties;
try {
properties = new Properties();
properties.put(Context.INITIAL_CONTEXT_FACTORY,"weblogic.jndi.WLInitialContextFactory");
properties.put(Context.PROVIDER_URL, url);
if (user != null) {
properties.put(Context.SECURITY_PRINCIPAL, user);
properties.put(Context.SECURITY_CREDENTIALS,password == null ? "" : password);
}
return new javax.naming.InitialContext(properties);
}
catch (Exception e) {
System.out.println("Unable to connect to WebLogic server at " + url);
System.out.println("Please make sure that the server is running.");
throw e;
}
}
//返回应用服务器上下文
private Context getContext() throws Exception {
if (context == null) {
try {
context = getInitialContext();
}
catch (Exception ex) {
ex.printStackTrace();
throw ex;
}
}
return context;
}
//发布文本消息
public void publishText(String message) throws Exception {
javax.jms.TextMessage textMessage = getTopicSession(false).createTextMessage();
textMessage.clearBody();
textMessage.setText(message);
getTopicPublisher().publish(textMessage);
if (isTransacted()) {
getTopicSession(false).commit();
}
}
//发布对象消息
public void publishObject(Serializable message) throws Exception {
javax.jms.ObjectMessage objectMessage = getTopicSession(false).createObjectMessage();
objectMessage.clearBody();
objectMessage.setObject(message);
getTopicPublisher().publish(objectMessage);
if (isTransacted()) {
getTopicSession(false).commit();
}
}
//定义消息驱动Bean. 可以写在一个文件中 . 实现监听器类
public void onMessage(Message message) {
if (message instanceof javax.jms.BytesMessage) {
javax.jms.BytesMessage bytesMessage = (javax.jms.BytesMessage) message;
System.out.println("这是一个BytesMessage,内容是:" + bytesMessage);
/** @todo Process bytesMessage here */
}
else if (message instanceof javax.jms.MapMessage) {
javax.jms.MapMessage mapMessage = (javax.jms.MapMessage) message;
System.out.println("这是一个MapMessage,内容是:" + mapMessage);
/** @todo Process mapMessage here */
}
else if (message instanceof javax.jms.ObjectMessage) {
javax.jms.ObjectMessage objectMessage = (javax.jms.ObjectMessage) message;
System.out.println("这是一个objectMessage,内容是:" + objectMessage);
/** @todo Process objectMessage here */
}
else if (message instanceof javax.jms.StreamMessage) {
javax.jms.StreamMessage streamMessage = (javax.jms.StreamMessage) message;
System.out.println("这是一个StreamMessage,内容是:" + streamMessage);
/** @todo Process streamMessage here */
}
else if (message instanceof javax.jms.TextMessage) {
javax.jms.TextMessage objectMessage = (javax.jms.TextMessage) message;
System.out.println("这是一个TextMessage,内容是:" + objectMessage);
/** @todo Process textMessage here */
}
if (isTransacted()) {
try {
getTopicSession(false).commit();
}
catch (Exception ex) {
ex.printStackTrace();
}
}
}
//释放资源
public void close() throws Exception {
if (topicPublisher != null) {
topicPublisher.close();
}
if (topicSubscriber != null) {
topicSubscriber.close();
}
if (topicSession != null) {
topicSession.close();
}
if (topicConnection != null) {
topicConnection.close();
}
System.out.println("Release Resource");
}
/******************************************************************************************************************/
// 测试
/******************************************************************************************************************/
public static void main(String[] args) throws InterruptedException, Exception {
JMSpublicTest jMsPublic = new JMSpublicTest();
jMsPublic.setDurable(true);
jMsPublic.setClientId("IP:192.168.0.102");
jMsPublic.setDurableName("test226aa");
TopicSubscriber topicSub = jMsPublic.getTopicSubscriber();
//开始发布一个消息
JMSpublicTest jtp = new JMSpublicTest();
jtp.setDurable(true);
jtp.setClientId("ip:192.168.0.114");
jtp.setDurableName("test226aa");
jtp.publishText("发布一个消息!!!");
jtp.publishText("发布一个消息!!!");
// System.out.println("Topic Name=="+topicSub.getTopic().getTopicName());
jtp.close();
//在这里保持监听来获取消息
synchronized (jMsPublic) {
jMsPublic.wait(10000);
}
jMsPublic.close();
// System.out.println(jtp.getClientId());
System.out.println("接收消息");
}
}
分享到:
相关推荐
- **发布/订阅(Publish/Subscribe, Pub/Sub)**:在这种模型中,消息从一个生产者发布到一个主题,多个订阅者可以订阅这个主题并接收相同的消息。 **WebLogic JMS Server** WebLogic Server 是Oracle公司的一个...
它支持点对点(P2P)和发布/订阅(Pub/Sub)两种消息模型。 - **组件**:主要包括队列(Queue)、主题(Topic)、消息生产者(Message Producer)、消息消费者(Message Consumer)和消息驱动bean(Message-Driven ...
- JMS 是一种标准的API,它使Java应用程序能够与消息系统交互,支持点对点(P2P)和发布/订阅(Pub/Sub)两种消息传递模式。 - 功能包括:认可的消息传递、事务型消息、一致性消息和持久性订阅者支持,有助于与旧...
Weblogic 10 中的 JMS (Java Message Service) 和 MDB (Message-Driven Bean) 是企业级应用开发中的核心组件,用于实现异步处理和解耦应用程序。JMS 是一个标准接口,允许 Java 应用程序与其他应用程序进行消息传递...
它的主要目标是提供可靠的、跨平台的消息传递,支持点对点(P2P)和发布/订阅(Pub/Sub)两种模式。在Spring框架中,JMS的配置简化了消息生产者和消费者的实现。 在WebLogic 8.1这个特定的环境中,我们需要先确保...
JMS中有两种主要的消息类型:点对点(Point-to-Point,P2P)和发布/订阅(Publish/Subscribe,Pub/Sub)模式。 在点对点模式中,消息被发送到一个称为队列的特定目标,每个消息只有一个消费者。而在发布/订阅模式中...
它支持两种消息模式:点对点(Point-to-Point,P2P)和发布/订阅(Publish/Subscribe,Pub/Sub)。在点对点模式中,消息从一个队列中发送到另一个队列,每个消息仅被一个消费者消费。而在发布/订阅模式下,消息发布...
- **发布/订阅(Publish/Subscribe, Pub/Sub)**:在这个模型中,一个消息可以被多个订阅者接收。发布者发送消息到主题,而订阅者可以订阅这些主题以接收消息。 **JMS基本功能** 1. **消息组件**:消息由三部分...
JMS提供了两个主要的消息域:点对点(PTP)和发布/订阅(Pub/Sub)。 1. **点对点(PTP)**:在此模式下,消息发送给特定的目标队列,每个消息会被一个消费者接收并消费。一旦消息被消费,就从队列中移除。 - **队列...
JMS支持两种消息模式:点对点(Point-to-Point,P2P)和发布/订阅(Publish/Subscribe,Pub/Sub)。 EJB3是EJB规范的一个版本,简化了企业级开发,引入了注解驱动和POJO(Plain Old Java Object)概念,降低了开发...
- **发布/订阅(Publish/Subscribe, Pub/Sub)**:这种模式下,消息发布者将消息发送到一个主题上,所有订阅了该主题的消费者都会收到这条消息。与点对点模式不同,发布/订阅模式允许消息被多个消费者同时接收。 ##...
JMS提供了两种消息传递模式:点对点(PTP)和发布/订阅(Pub/Sub)。PTP模式中,消息被放入队列中,然后队列中的消息由一个或多个消费者轮流处理。而在Pub/Sub模式中,消息被发布到主题中,任何订阅了该主题的消费者...
1. **消息通信模型**:WebLogic JMS支持PTP和Pub/Sub两种模型,每种模型都有其特定的应用场景。 2. **消息组成**:消息由头、属性和主体三部分构成。头包含标准字段,属性允许自定义分类,主体则根据消息类型有不同...
- **消息服务体系结构**:JMS定义了两种主要的消息传送模型——点对点(Point-to-Point, PTP)和发布/订阅(Publish/Subscribe, Pub/Sub)模型。 - **消息传送模型对照表**:PTP模式使用Queue,消息只能被一个消费...
JMS提供两种主要的消息模型:点对点(Point-to-Point, P2P)和发布/订阅(Publish/Subscribe, Pub/Sub)。在点对点模型中,消息从一个生产者发送到一个队列,然后由一个或多个消费者接收。发布/订阅模型下,消息发布...
- **发布/订阅(Publish/Subscribe, Pub/Sub)模型**:在发布/订阅模型中,生产者(发布者)将消息发送到一个主题,多个消费者(订阅者)可以订阅该主题并接收消息。这种方式支持一对多的广播通信,允许消息被多个...
JMS API提供了多种消息模式,包括点对点(Point-to-Point, PTP)和发布/订阅(Publish/Subscribe, Pub/Sub)模型,以适应不同的应用场景。在点对点模型中,消息由一个生产者发送到一个队列,然后被一个或多个消费者...
2. **发布/订阅(Pub-Sub)**:类似于广播通信,如在论坛或聊天室中。消息被发布到一个主题,多个订阅者可以接收同一消息。所有订阅该主题的消费者都能收到消息,且消息可能会被多个消费者同时处理。 JMS API包括...
对于 PTP 类型,Destinations 对应的类型为 Queue,对于 Pub/Sub 类型,Destinations 对应的类型为 Topic。 Connections:Connections 为客户端和消息服务器建立的一个连接,它可以创建 Session,并且可以创建多个 ...