RabbitMQ发送JSON字符串,解决接收端解析成对象报错

发送端把对象转为JSON字符串,

 public <T>boolean sendToQueue(String queueName, T data){
        try{
            amqpTemplate.convertAndSend(queueName, JSON.toJSONString(data));
            return true;
        }catch (Exception e){
            return false;
        }
    }

接收端解析的时候报错:com.alibaba.fastjson.JSONException: syntax error, expect {, actual error, pos 0

JSONObject.parseObject(s, QrSignInData.class);

解决办法如下:

 @RabbitListener(queues = "MAIN_QUEUE")
    public void process(String data){
        System.out.println(data);
        log.info("[RabbitMQ]----收到消息:{}",data);
        final JSONObject jsonObject = JSONObject.parseObject(data);
        final String qq = jsonObject.getString("qq");
        final String s = jsonObject.toJSONString();
        log.info(qq);
        try{
           final QrSignInData qrSignInData = JSONObject.parseObject(s, QrSignInData.class);
           iMacUserService.toUpdateUserPoint(qrSignInData);
       }catch (Exception e){

       }
    }

 

Java中,使用RabbitMQ作为消息中间件将数据拆分并批量发送通常涉及以下步骤: 1. **添加依赖**: 首先,你需要在项目中引RabbitMQ客户端库,比如Spring AMQP、RabbitMQ Java Client等。 2. **创建生产者(Publisher)**: 创建一个Java类,配置连接到RabbitMQ服务器。使用`MessageBuilder`或`BasicProperties`构建消息。例如,你可以将数据分割多个`Map`或自定义对象,然后将其转换JSON字符串以便序列化。 ```java import org.springframework.amqp.core.Message; import org.springframework.amqp.rabbit.annotation.RabbitListener; import org.springframework.amqp.rabbit.core.RabbitTemplate; public class DataProducer { private final RabbitTemplate rabbitTemplate; public DataProducer(RabbitTemplate rabbitTemplate) { this.rabbitTemplate = rabbitTemplate; } @RabbitListener(queues = "data_queue") public void sendData(String[] dataParts) { for (String part : dataParts) { Message message = new Message(part.getBytes(), // 转换为字节数组 new BasicProperties.Builder() .build()); rabbitTemplate.convertAndSend("data_topic", message); } } } ``` 3. **数据拆分**: 在发送数据之前,需要将原始数据拆分为多个部分。这可以根据你的需求进行定制,例如按固定大小切分或者按照每条消息的最大允许大小。 4. **消费者(Consumer)**: 消费端监听指定的主题(`"data_topic"`),并处理接收到的消息。当数据到达时,可以解析消息内容,并进行相应的处理。 ```java import org.springframework.amqp.rabbit.annotation.RabbitListener; import org.springframework.stereotype.Component; @Component public class DataConsumer { @RabbitListener(queues = "data_queue") public void receiveData(String receivedPart) { // 解析、处理或者存储接收到的数据 System.out.println("Received data part: " + receivedPart); } } ``` 5. **启动与配置**: 在应用启动时,初始化RabbitMQ连接,并启用消费者的监听。确保配置了正确的RabbitMQ服务器地址、队列和交换机。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值