Rabbitmq的消息转换器

Spring会把你发送的消息序列化为字节发送给MQ,接收消息的时候,还会把字节反序列化为Java对象 ,只不过,默认情况下Spring采用的序列化方式是JDK序列化。众所周知,JDK序列化存在下列问题:

  • 数据体积过大

  • 有安全漏洞

  • 可读性差

默认转换器

发送一个Map对象  

@Test
public void testSendMap() throws InterruptedException {
    // 准备消息
    Map msg = new HashMap<>();
    msg.put("name", "Jack");
    msg.put("age", 21);
    // 发送消息
    rabbitTemplate.convertAndSend("simple.queue","", msg);
}

发送消息后查看控制台 Rabbitmq的消息转换器_第1张图片 

配置JSON转换器

显然,JDK序列化方式并不合适。我们希望消息体的体积更小、可读性更高,因此可以使用JSON方式来做序列化和反序列化。

引入依赖 

在publisher和consumer两个服务中都引入依赖


    com.fasterxml.jackson.dataformat
    jackson-dataformat-xml
    2.9.10

 配置消息转换器

在启动类中添加一个Bean即可

@Bean
public MessageConverter jsonMessageConverter(){
    return new Jackson2JsonMessageConverter();
}

 发送一个Map对象  

@Test
public void testSendMap() throws InterruptedException {
    // 准备消息
    Map msg = new HashMap<>();
    msg.put("name", "Jack");
    msg.put("age", 21);
    // 发送消息
    rabbitTemplate.convertAndSend("simple.queue","", msg);
}

 rabbitmq查看消息

Rabbitmq的消息转换器_第2张图片

 消息体的体积更小、可读性更高,因此可以使用JSON方式来做序列化和反序列化。

你可能感兴趣的:(rabbitmq,java,开发语言)