我们在使用RabbitMQ时,消息发送者需要调用RabbitTemplate
的rconvertAndSend()
方法来实现消息的发送,当我们发送基本数据类型的消息时,MQ可以正确的读取我们的消息并且以消息原本的形式展现给我们
这里用一个测试代码来演示,先定义队列和交换机
@RabbitListener(bindings = @QueueBinding(
value = @Queue(name = "test.queue", durable = "true"),
exchange = @Exchange(name = "test.direct", type = ExchangeTypes.DIRECT),
key = {"test"}
))
public void listenTestQueue(String message){
System.out.println("test.queue 接收到 => " + message);
}
发送消息代码
@Test
void SendMessage(){
rabbitTemplate.convertAndSend("test.direct", "test", "hello");
}
这里可以消费者可以正常的接收到发送的消息,我们使用高级数据结构Map试一试
这里我们先修改RabbitListener的接收类型为HashMap
@RabbitListener(bindings = @QueueBinding(
value = @Queue(name = "test.queue", durable = "true"),
exchange = @Exchange(name = "test.direct", type = ExchangeTypes.DIRECT),
key = {"test"}
))
public void listenTestQueue(HashMap<String, Object> message){
System.out.println("test.queue 接收到 => " + message);
}
修改发送消息的代码
@Test
void SendMessage(){
HashMap<String, Object> message = new HashMap<>(2);
message.put("name", "小明");
message.put("age", 20);
rabbitTemplate.convertAndSend("test.direct", "test", message);
}
这里发现消息变成了复杂且看不懂的乱码,这是为什么呢?我们先去看一下convertAndSend()
方法的源码,这里可以看到,方法接收消息是用的是Object
来接收的
而在数据传输时,它会把你发送的消息序列化为字节发送给MQ,接收消息的时候,还会把字节反序列化为Java对象。
只不过,默认情况下Spring采用的序列化方式是JDK序列化。众所周知,JDK序列化存在下列问题:
- 数据体积过大
- 有安全漏洞
- 可读性差
我们可以使用JSON方式来做序列化和反序列化,先引入jackson相关的依赖
<!--jackson-->
<dependency>
<groupId>com.fasterxml.jackson.dataformat</groupId>
<artifactId>jackson-dataformat-xml</artifactId>
<version>2.9.10</version>
</dependency>
添加完后我们去在消费者和发送者部分都配置消息转换器
@Bean
public MessageConverter messageConverter(){
return new Jackson2JsonMessageConverter();
}
再次执行发送消息的代码,发现可以正确的显示出来发送的消息