java - RabbitMQ 发送对象

标签 java networking rabbitmq system-integration

您好,我是 RabbitMQ 的新手,我正在尝试在 2 个应用程序之间发送一个对象,但它不起作用然后我发现我需要序列化和反序列化这些对象,但它仍然无法正常工作。当我发送一个字符串时没有问题,但是对于对象它突然不起作用,应用程序之间没有连接,我不确定我做错了什么。

这是 Sender.java :

import org.apache.commons.lang3.SerializationUtils;
import com.rabbitmq.client.ConnectionFactory;
import com.rabbitmq.client.Connection;
import com.rabbitmq.client.Channel;

import java.io.ByteArrayOutputStream;
import java.io.ObjectOutput;
import java.io.ObjectOutputStream;

public class App {

private final static String QUEUE_NAME = "12345";

public static void main(String[] argv) throws Exception {

    ConnectionFactory factory = new ConnectionFactory();

    factory.setHost("somehost"); 
    factory.setUsername("guest"); 
    // factory.setPassword( "password" ); 
    //factory.setPort( 12345 ); 

    Connection connection = factory.newConnection();
    Channel channel = connection.createChannel();

    channel.queueDeclare(QUEUE_NAME, false, false, false, null);

    Car car = new Car(4, 4, "Mercedes");

    byte[] data = SerializationUtils.serialize(car);

    channel.basicPublish("", QUEUE_NAME, null, data);
    System.out.println(" [x] Sent '" + data + "'");

    channel.close();
    connection.close();
   }
}

这是 Receiver.java :
import org.apache.commons.lang3.SerializationUtils;
import com.rabbitmq.client.*;
import java.io.IOException;

public class Recipient {

     private final static String QUEUE_NAME = "12345";

public static void main(String[] argv) throws Exception {
    ConnectionFactory factory = new ConnectionFactory();
    factory.setHost("Somehost");
    factory.setUsername("guest"); 
    Connection connection = factory.newConnection();
    Channel channel = connection.createChannel();

    channel.queueDeclare(QUEUE_NAME, false, false, false, null);
    System.out.println(" [*] Waiting for messages. To exit press CTRL+C");
    Consumer consumer = new DefaultConsumer(channel) {

        @Override
        public void handleDelivery(String consumerTag, Envelope envelope, AMQP.BasicProperties properties, byte[] body)
                throws IOException {

            String message = new String(body, "UTF-8");
            //byte [] data = new byte[];

            Object object =    SerializationUtils.deserialize(message.getBytes());

            System.out.println(" [x] Received '" + object + "'");
         }
      };
    channel.basicConsume(QUEUE_NAME, true, consumer);
     }
    }

最佳答案

@Override
    public void handleDelivery(String consumerTag, Envelope envelope, AMQP.BasicProperties properties, byte[] body)
            throws IOException {
        //byte [] data = new byte[];

        Object object =    SerializationUtils.deserialize(body);

        System.out.println(" [x] Received '" + object + "'");
     }
  };

直接从 body 反序列化多变的

关于java - RabbitMQ 发送对象,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46606427/

相关文章:

networking - 让 Laravel Homestead 可以通过互联网访问

python - 使用pika,是否可以读取rabbitmq绑定(bind)参数?

go - 函数末尾缺少返回

Java 日历 DAY_OF_WEEK 设置为零

java - 添加Interceptor并使用Dagger2注入(inject)后Retrofit服务始终为空

c++ - 序列化优于 sockets c++ 的优势

rabbitmq - ACCESS_REFUSED - 使用身份验证机制 PLAIN 拒绝登录

java - 如何在 java 代码中读取 View 的 android 默认属性

java - 使用 JavaFX 设置应用程序图标时出现问题

linux - 网络映射/mon 工具阻塞 telnet 守护进程/登录进程