JMS规范中五种消息类型
来源:互联网 发布:php 连接hadoop 编辑:程序博客网 时间:2024/06/05 18:00
摘要: 本文讲述了JMS规范中五种消息类型,包括TextMessage、BytesMessage、MapMessage、StreamMessage和ObjectMessage
1.前言
ActiveMQ学习笔记(四)——通过ActiveMQ收发消息http://my.oschina.net/xiaoxishan/blog/380446 和ActiveMQ学习笔记(五)——使用Spring JMS收发消息http://my.oschina.net/xiaoxishan/blog/381209 中,发送和接受的消息类型都是TextMessage,即文本消息(如下面的代码所示)。显然消息类型只有文本类型是不能满足要求的。
//发送文本消息
session.createTextMessage(msg);
//接受文本消息
public void onMessage(Message msg) {
TextMessage message = (TextMessage) msg;
……
}
根据Message接口的方法,可以获取消息类型
String msgType = getJMSType()
根据 JSR 914: JavaTM Message Service (JMS) API ,JMS规范中的消息类型包括TextMessage、BytesMessage、MapMessage、StreamMessage和ObjectMessage等五种。ActiveMQ也有对应的实现,下面我们结合Spring JMS分别来看一下五种消息类型的收发代码。
2. 消息发送示例代码
/**
* 向默认队列发送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.消息接受示例代码
/**
* 接受消息
*/
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());
}
}
- JMS规范中五种消息类型
- JMS消息类型模型
- JMS消息类型
- JMS消息类型模型
- JMS消息类型
- JMS消息类型模型
- JMS消息类型
- JMS消息类型
- JMS规范介绍(1) JMS消息
- JMS规范,ActiveMQ消息中间件
- Java消息中间件--JMS规范
- 测试JMS消息类型JMS(五)
- jms消息类型(转)
- JMS有哪些消息类型
- 浅谈消息队列之JMS消息服务规范
- JMS的5中消息类型
- jms规范
- jms规范
- Javascript的in关键字
- Unity的WWW网络动态加载和储存在本地
- boost::share_ptr智能指针使用示例
- linux之守护进程的创建
- [Azure] 使用Azure Powershell脚本查看账号下所有订阅中的云服务公网IP地址绑定情况
- JMS规范中五种消息类型
- ANTLR4-实践
- $.ajax() 、$.post()、$.get() 的详解
- Android ContentProvider
- Linux权限修改
- virtualbox安装增强工具失败解决方法
- 【unity系统模块开发】自动寻路Navmesh
- 第三本书 unit1 DNS
- Android:透明状态栏