Java 卡夫卡制作发送图像

Java 卡夫卡制作发送图像,java,image,apache-kafka,Java,Image,Apache Kafka,我有以下卡夫卡制作人代码。我想知道我是否可以发送图像文件而不是JSON文件?是否有代码参考通过Kafka producer发送图像文件 try { URL url = getClass().getResource("test.json"); File file = new File(url.getPath()); Properties props = new Proper

我有以下卡夫卡制作人代码。我想知道我是否可以发送图像文件而不是JSON文件?是否有代码参考通过Kafka producer发送图像文件

    try {           
                URL url = getClass().getResource("test.json");
                File file = new File(url.getPath());
                Properties props = new Properties();            
                props.put("bootstrap.servers", "yupsectory.selet.com:9092");
                props.put("client.id", CLIENT_ID);
                props.put("key.serializer", "org.apache.kafka.common.serialization.StringSerializer");
                props.put("value.serializer", "org.apache.kafka.common.serialization.StringSerializer");
                String jsonData = readFile(file.getAbsolutePath());
                JSONObject jobj = new JSONObject(jsonData);    
                System.out.println("jarr: " + jobj.getJSONObject("data").toString());    

                Producer<String, String> producer = new KafkaProducer <>(props);      
                //Use this util to pull the context that needs to be propagated from the HttpServletRequest
                Map<String, String> headermap = YupsectoryContextUtil.buildContextMap(request);
                //Sending a message
                ProducerRecord<String, String> record = new ProducerRecord<String, String>(topic, jobj.getJSONObject("data").toString());
                producer.send(record, headermap);           
                producer.close();                 
            } catch (JSONException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }

图像可以作为消息值中的字节数组发送。因此,您的代码将按照给定的方式进行更改

props.put("value.serializer", "org.apache.kafka.common.serialization.ByteArraySerializer");

您可以通过以下简单步骤发送图像:

1通过搜索如何获取图像文件的字节,将图像转换为字节数组

2将此行更改为:-

props.put("value.serializer", "org.apache.kafka.common.serialization.StringSerializer");
致:-

3给出图像文件的字节数组


还有,你可以走了。

你到底想要什么?你试过了吗?你有什么问题吗?对于初学者来说,你不会对图像文件使用任何JSON类或字符串。。。您将发送字节,并使用ByteArraySerializer。。。因此,您应该询问或搜索如何在Java中获取图像文件的字节
props.put("value.serializer", "org.apache.kafka.common.serialization.ByteArraySerializer");