`
xiaobian
  • 浏览: 589628 次
  • 来自: 北京
社区版块
存档分类
最新评论
阅读更多
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("接收消息");
	    

	  }

}


分享到:
评论

相关推荐

    Java-JMS实例

    - **发布/订阅(Publish/Subscribe, Pub/Sub)**:在这种模型中,消息从一个生产者发布到一个主题,多个订阅者可以订阅这个主题并接收相同的消息。 **WebLogic JMS Server** WebLogic Server 是Oracle公司的一个...

    Weblogic_JMS+配置数据源配置

    它支持点对点(P2P)和发布/订阅(Pub/Sub)两种消息模型。 - **组件**:主要包括队列(Queue)、主题(Topic)、消息生产者(Message Producer)、消息消费者(Message Consumer)和消息驱动bean(Message-Driven ...

    WebLogic_server8.1_JMS入门.doc

    - JMS 是一种标准的API,它使Java应用程序能够与消息系统交互,支持点对点(P2P)和发布/订阅(Pub/Sub)两种消息传递模式。 - 功能包括:认可的消息传递、事务型消息、一致性消息和持久性订阅者支持,有助于与旧...

    Weblogic10_JMS、MDB分布式部署学习

    Weblogic 10 中的 JMS (Java Message Service) 和 MDB (Message-Driven Bean) 是企业级应用开发中的核心组件,用于实现异步处理和解耦应用程序。JMS 是一个标准接口,允许 Java 应用程序与其他应用程序进行消息传递...

    jms.rar_weblogic8 spring jms

    它的主要目标是提供可靠的、跨平台的消息传递,支持点对点(P2P)和发布/订阅(Pub/Sub)两种模式。在Spring框架中,JMS的配置简化了消息生产者和消费者的实现。 在WebLogic 8.1这个特定的环境中,我们需要先确保...

    Weblogic提供JMS服务Demo

    JMS中有两种主要的消息类型:点对点(Point-to-Point,P2P)和发布/订阅(Publish/Subscribe,Pub/Sub)模式。 在点对点模式中,消息被发送到一个称为队列的特定目标,每个消息只有一个消费者。而在发布/订阅模式中...

    Weblogic环境下JMS配置

    它支持两种消息模式:点对点(Point-to-Point,P2P)和发布/订阅(Publish/Subscribe,Pub/Sub)。在点对点模式中,消息从一个队列中发送到另一个队列,每个消息仅被一个消费者消费。而在发布/订阅模式下,消息发布...

    jms学习指导(weblogic下的)

    - **发布/订阅(Publish/Subscribe, Pub/Sub)**:在这个模型中,一个消息可以被多个订阅者接收。发布者发送消息到主题,而订阅者可以订阅这些主题以接收消息。 **JMS基本功能** 1. **消息组件**:消息由三部分...

    JMS--J2EE培训材料

    JMS提供了两个主要的消息域:点对点(PTP)和发布/订阅(Pub/Sub)。 1. **点对点(PTP)**:在此模式下,消息发送给特定的目标队列,每个消息会被一个消费者接收并消费。一旦消息被消费,就从队列中移除。 - **队列...

    jms-ejb3 source code

    JMS支持两种消息模式:点对点(Point-to-Point,P2P)和发布/订阅(Publish/Subscribe,Pub/Sub)。 EJB3是EJB规范的一个版本,简化了企业级开发,引入了注解驱动和POJO(Plain Old Java Object)概念,降低了开发...

    JAVA中的JMS是什么意思?它起了什么作用_即时通讯使用问题_PConline快问

    - **发布/订阅(Publish/Subscribe, Pub/Sub)**:这种模式下,消息发布者将消息发送到一个主题上,所有订阅了该主题的消费者都会收到这条消息。与点对点模式不同,发布/订阅模式允许消息被多个消费者同时接收。 ##...

    JMS学习手册

    JMS提供了两种消息传递模式:点对点(PTP)和发布/订阅(Pub/Sub)。PTP模式中,消息被放入队列中,然后队列中的消息由一个或多个消费者轮流处理。而在Pub/Sub模式中,消息被发布到主题中,任何订阅了该主题的消费者...

    JMS简介 Java Message Service

    1. **消息通信模型**:WebLogic JMS支持PTP和Pub/Sub两种模型,每种模型都有其特定的应用场景。 2. **消息组成**:消息由头、属性和主体三部分构成。头包含标准字段,属性允许自定义分类,主体则根据消息类型有不同...

    JMS 简单使用指南

    - **消息服务体系结构**:JMS定义了两种主要的消息传送模型——点对点(Point-to-Point, PTP)和发布/订阅(Publish/Subscribe, Pub/Sub)模型。 - **消息传送模型对照表**:PTP模式使用Queue,消息只能被一个消费...

    jms中间件设计源代码下载.zip

    JMS提供两种主要的消息模型:点对点(Point-to-Point, P2P)和发布/订阅(Publish/Subscribe, Pub/Sub)。在点对点模型中,消息从一个生产者发送到一个队列,然后由一个或多个消费者接收。发布/订阅模型下,消息发布...

    有关JMS/或j2ee技术的说明与问题

    - **发布/订阅(Publish/Subscribe, Pub/Sub)模型**:在发布/订阅模型中,生产者(发布者)将消息发送到一个主题,多个消费者(订阅者)可以订阅该主题并接收消息。这种方式支持一对多的广播通信,允许消息被多个...

    JMS两个开发包

    JMS API提供了多种消息模式,包括点对点(Point-to-Point, PTP)和发布/订阅(Publish/Subscribe, Pub/Sub)模型,以适应不同的应用场景。在点对点模型中,消息由一个生产者发送到一个队列,然后被一个或多个消费者...

    jms详解,介绍jms必备哟

    2. **发布/订阅(Pub-Sub)**:类似于广播通信,如在论坛或聊天室中。消息被发布到一个主题,多个订阅者可以接收同一消息。所有订阅该主题的消费者都能收到消息,且消息可能会被多个消费者同时处理。 JMS API包括...

    JMS详细实例学习教程

    对于 PTP 类型,Destinations 对应的类型为 Queue,对于 Pub/Sub 类型,Destinations 对应的类型为 Topic。 Connections:Connections 为客户端和消息服务器建立的一个连接,它可以创建 Session,并且可以创建多个 ...

Global site tag (gtag.js) - Google Analytics