SpringAMQP-消息转换器

这边发送消息接收消息默认是jdk的序列化方式,发送到服务器是以字节码的形式,我们看不懂也很占内存,所以我们要手动设置一下 我这边设置成json的序列化方式,注意发送方和接收方的序列化方式要保持一致 不然回报错。

引入依赖,建议直接在父工程引入。

        <dependency>
            <groupId>com.fasterxml.jackson.dataformat</groupId>
            <artifactId>jackson-dataformat-xml</artifactId>
            <version>2.9.10</version>
        </dependency>

在配置类里配置一下:接收方和发送方都要有

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

配置好之后编写测试代码:

向object.queue队列发送map的消息

    @Test
    public void testObjectQueue(){
        Map<Integer,String> map = new HashMap<>();
        String queueName="object.queue";
        map.put(1,"刘岚");
        map.put(2,"范冰冰");
        rabbitTemplate.convertAndSend(queueName, map);
    }

接收该消息:

    @RabbitListener(queues = "object.queue")
    public void listenObjectQueue(Map<Integer, String> msg) {
        System.out.println("从object.queue中接收到消息:" + msg);
    }

测试成功:

测试失败是这样:如果接收者和发送者的序列化不一样会报这样的错

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值