RabbitMq 实现消息自动序列化和反序列化的配置

本文介绍了如何在RabbitMQ中设置消息的自动序列化和反序列化,确保数据在发送和接收过程中的正确传输。通过正确的配置,可以实现不同系统间的数据交换,提高系统的兼容性和效率。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

配置 

@Configuration
public class RabbitMqConfig implements RabbitListenerConfigurer {



    //以下配置RabbitMQ消息服务
    @Autowired
    public ConnectionFactory connectionFactory;

    @Bean
    public DefaultMessageHandlerMethodFactory myHandlerMethodFactory() {
        DefaultMessageHandlerMethodFactory factory = new DefaultMessageHandlerMethodFactory();
        // 这里的转换器设置实现了 通过 @Payload 注解 自动反序列化message body
        factory.setMessageConverter(new MappingJackson2MessageConverter());
        return factory;
    }

    @Override
    public void configureRabbitListeners(RabbitListenerEndpointRegistrar registrar) {
        registrar.setMessageHandlerMethodFactory(myHandlerMethodFactory());
    }

    @Bean
    public SimpleRabbitListenerContainerFactory rabbitListenerContainerFactory() {
        SimpleRabbitListenerContainerFactory factory = new SimpleRabbitListenerContainerFactory();
        factory.setConnectionFactor
### 处理 RabbitMQ 消费者端的消息反序列化问题 为了确保 RabbitMQ 的消费者能够正确地对接收到的消息进行反序列化,需要在生产者消费者两端都配置相同的消息转换器。通常情况下,默认的消息转换器 `SimpleMessageConverter` 仅能处理简单的字符串或字节数组消息,对于复杂对象则无能为力。 通过使用 Spring Boot 提供的 `Jackson2JsonMessageConverter` 转换器,可以方便地将 Java 对象序列化成 JSON 字符串发送,并能在接收时自动将其还原回原始的对象形式[^3]。这不仅简化了开发工作量,还提高了系统的灵活性与可维护性。 #### 配置自定义 `RabbitTemplate` 在任意配置类中创建并注册一个带有特定消息转换器的 `RabbitTemplate` 实例: ```java @Bean public RabbitTemplate jacksonRabbitTemplate(ConnectionFactory connectionFactory) { RabbitTemplate rabbitTemplate = new RabbitTemplate(connectionFactory); rabbitTemplate.setMessageConverter(new Jackson2JsonMessageConverter()); return rabbitTemplate; } ``` 此段代码的作用在于替换掉默认的 `RabbitTemplate`,使得所有的消息都将被转化为 JSON 格式的字符串来传输。 #### 设置监听器处理器工厂 为了让消费者的监听器也支持同样的 JSON 反序列化逻辑,在应用程序启动时需调用 `configureRabbitListeners()` 方法来自定义 `messageHandlerMethodFactory()`: ```java @Override public void configureRabbitListeners(RabbitListenerEndpointRegistrar registrar) { registrar.setMessageHandlerMethodFactory(messageHandlerMethodFactory()); } @Bean public DefaultMessageHandlerMethodFactory messageHandlerMethodFactory() { DefaultMessageHandlerMethodFactory factory = new DefaultMessageHandlerMethodFactory(); factory.setMessageConverter(new MappingJackson2MessageConverter()); return factory; } ``` 上述操作确保了当接收到新消息时,会先经过指定的消息转换器解析再交给实际业务方法处理[^2]。 #### 自定义对象的要求 如果要传送的是自定义类型的对象,则该类应该实现 `Serializable` 接口以便于 JVM 进行正常的序列化过程。同时也要记得在生产消费两侧均应用相同的配置以保持一致性[^4]。
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值