RabbitMQ消息Json序列化Could not convert incoming message with content-type

1:未配置外部RabbitMQ

在原本消息序列化中:JDK序列化方式并不合适。我们希望消息体的体积更小、可读性更高,因此可以使用JSON方式来做序列化和反序列化。 在父工程的pom文件中引入依赖:

 <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();
 }

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

  • 数据体积过大

  • 有安全漏洞

  • 可读性差

2:配置了RabbitMQ

这里寻找bug超级久,就是因为配置了外部的RabbitTemplate:

当你在Spring外部配置MessageConverter时,它将不会对RabbitTemplate产生影响。在Spring中使用@Bean注解定义的RabbitTemplate bean,它会自动将其关联的默认MessageConverter设置为SimpleMessageConverter

如果你希望在Spring外部配置MessageConverter,你需要手动将其设置给RabbitTemplate。你可以修改你的代码如下:

@Bean
public RabbitTemplate rabbitTemplate(MyCallback myCallback) {
    RabbitTemplate rabbitTemplate = new RabbitTemplate(connectionFactory);
    rabbitTemplate.setConfirmCallback(myCallback);
    rabbitTemplate.setMessageConverter(new Jackson2JsonMessageConverter());
    return rabbitTemplate;
}

通过在rabbitTemplate方法中添加MessageConverter参数,并将其与rabbitTemplate.setMessageConverter()方法一起使用,你可以将外部配置的MessageConverter应用到RabbitTemplate中。

这样,当你使用RabbitTemplate时,它将使用你在外部配置的Jackson2JsonMessageConverter。记得在外部的配置类上添加@Configuration注解以确保它被正确扫描和加载。

成功:

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值