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
注解以确保它被正确扫描和加载。
下载/导出问题(统一返回):No converter for xxx with preset Content-Type ‘application/octet-stream;charset=UTF-8
在处理统一身份认证平台推送的RabbitMQ消息时,监听器代码如下:
import org.springframework.amqp.rabbit.annotation.RabbitHandler;
import org.springframework.amqp.rabbit.annotation.RabbitListener;
import org.springframework.stereotype.Component;
@Component
@RabbitListener(queues = "xxx
问题描述:
org.springframework.amqp.rabbit.support.ListenerExecutionFailedException: Failed to convert message
Caused by: org.springframework.amqp.AmqpException: No method found for class java.lang.String
问题分析:
1、消息生产者发送的消息类型为String,消息消费者接收的消息类