Rabbitmq的消息转换器

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

  • 数据体积过大

  • 有安全漏洞

  • 可读性差

默认转换器

发送一个Map对象

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

发送消息后查看控制台

配置JSON转换器

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

引入依赖

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

复制代码
<dependency>
    <groupId>com.fasterxml.jackson.dataformat</groupId>
    <artifactId>jackson-dataformat-xml</artifactId>
    <version>2.9.10</version>
</dependency>

配置消息转换器

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

复制代码
@Bean
public MessageConverter jsonMessageConverter(){
    return new Jackson2JsonMessageConverter();
}

发送一个Map对象

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

rabbitmq查看消息

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

相关推荐
伊灵eLing2 分钟前
GoLang 语言基础
开发语言·后端·golang
两年半的个人练习生^_^2 分钟前
JMM 进阶:彻底理解 synchronized 实现原理
java·开发语言
小白不白1114 分钟前
Invoke的用法
开发语言·人工智能·数码相机·计算机视觉·c#
techdashen8 分钟前
What is maintenance, anyway?
开发语言·后端·rust
戳代码的新星9 分钟前
论小白如何学会使用Maven
java·maven
wyhwust9 分钟前
maven的安装和配置
java
万法若空11 分钟前
C/C++基本类型表示范围
c语言·开发语言·c++
yijianace14 分钟前
Python爬虫实战:BooksToScrape 多线程爬取与图片下载
开发语言·爬虫·python
plainGeekDev20 分钟前
HttpURLConnection → OkHttp + Kotlin
android·java·kotlin
凡人叶枫21 分钟前
Effective C++ 条款15:在资源管理类中提供对原始资源的访问
linux·开发语言·c++·stm32·单片机