ActiveMQ學習筆記(6)——JMS消息類型

1.前言

        ActiveMQ學習筆記(四)——通過ActiveMQ收發消息http://my.oschina.net/xiaoxishan/blog/380446 和ActiveMQ學習筆記(五)——使用Spring JMS收發消息http://my.oschina.net/xiaoxishan/blog/381209   中,發送和接受的消息類型都是TextMessage,即文本消息(如下面的代碼所示)。顯然消息類型只有文本類型是不能滿足要求的。

?
1
2
3
4
5
6
7
8
9
//發送文本消息
 session.createTextMessage(msg);
  
  
//接受文本消息
 public void onMessage(Message msg) {
    TextMessage message = (TextMessage) msg;
      ……
 }

   根據Message接口的方法,可以獲取消息類型

?
1
String msgType = getJMSType()

   

    根據 JSR 914: JavaTM Message Service (JMS) API ,JMS規範中的消息類型包括TextMessage、BytesMessage、MapMessage、StreamMessage和ObjectMessage 等五種。ActiveMQ也有對應的實現,下面我們結合Spring JMS分別來看一下五種消息類型的收發代碼。

2. 消息發送示例代碼

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
  /**
   * 向默認隊列發送text消息
   */
  public void sendMessage(final String msg) {
    String destination = jmsTemplate.getDefaultDestination().toString();
    System.out.println("ProducerService向隊列" + destination + "發送了消息:\t" + msg);
    jmsTemplate.send(new MessageCreator() {
      public Message createMessage(Session session) throws JMSException {
        return session.createTextMessage(msg);
      }
    });
  }
 
  /**
   * 向默認隊列發送map消息
   */
  public void sendMapMessage() {
    jmsTemplate.send(new MessageCreator() {
      public Message createMessage(Session session) throws JMSException {
        MapMessage message = session.createMapMessage();
        message.setString("name""小西山");
        return message;
      }
    });
  }
 
  /**
   * 向默認隊列發送Object消息
   */
  public void sendObjectMessage() {
    jmsTemplate.send(new MessageCreator() {
      public Message createMessage(Session session) throws JMSException {
        Staff staff = new Staff(1"搬磚工"); // Staff必須實現序列化
        ObjectMessage message = session.createObjectMessage(staff);
        return message;
      }
    });
  }
 
  /**
   * 向默認隊列發送Bytes消息
   */
  public void sendBytesMessage() {
    jmsTemplate.send(new MessageCreator() {
      public Message createMessage(Session session) throws JMSException {
        String str = "BytesMessage 字節消息";
        BytesMessage message = session.createBytesMessage();
        message.writeBytes(str.getBytes());
        return message;
      }
    });
  }
 
  /**
   * 向默認隊列發送Stream消息
   */
  public void sendStreamMessage() {
    jmsTemplate.send(new MessageCreator() {
      public Message createMessage(Session session) throws JMSException {
        String str = "StreamMessage 流消息";
        StreamMessage message = session.createStreamMessage();
        message.writeString(str);
        message.writeInt(521);
        return message;
      }
    });
  }


3.消息接受示例代碼

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
 /**
   * 接受消息
   */
  public void receive(Destination destination) throws JMSException {
    Message message = jmsTemplate.receive(destination);
    // 如果是文本消息
    if (message instanceof TextMessage) {
      TextMessage tm = (TextMessage) message;
      System.out.println("ConsumerService從隊列" + destination.toString() + "收到了消息:\t" + tm.getText());
    }
 
    // 如果是Map消息
    if (message instanceof MapMessage) {
      MapMessage mm = (MapMessage) message;
      System.out.println("ConsumerService從隊列" + destination.toString() + "收到了消息:\t"
          + mm.getString("name"));
    }
 
    // 如果是Object消息
    if (message instanceof ObjectMessage) {
      ObjectMessage om = (ObjectMessage) message;
      Staff staff = (Staff) om.getObject();
      System.out.println("ConsumerService從隊列" + destination.toString() + "收到了消息:\t" + staff);
    }
 
    // 如果是bytes消息
    if (message instanceof BytesMessage) {
      byte[] b = new byte[1024];
      int len = -1;
      BytesMessage bm = (BytesMessage) message;
      while ((len = bm.readBytes(b)) != -1) {
        System.out.println(new String(b, 0, len));
      }
    }
 
    // 如果是Stream消息
    if (message instanceof StreamMessage) {
      StreamMessage sm = (StreamMessage) message;
      System.out.println(sm.readString());
      System.out.println(sm.readInt());
    }
 
  }

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章