代码之家  ›  专栏  ›  技术社区  ›  Stella

卡夫卡制作发送图像

  •  0
  • Stella  · 技术社区  · 7 年前

    我有以下卡夫卡制片人代码。我想知道我是否可以发送图像文件而不是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();
                }
    
    2 回复  |  直到 7 年前
        1
  •  2
  •   officialrahulmandal    6 年前

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

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

    2) 将此行更改为:-

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

    致:-

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

    3) 给你的图像文件的字节数组

    而且,你可以走了。

        2
  •  2
  •   SCouto    6 年前

    图像可以作为消息值中的字节数组发送。所以你的代码会被修改。

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