gpt4 book ai didi

java - 如何通过在java中的post请求中发送文件将数据导入elasticsearch?

转载 作者:行者123 更新时间:2023-11-30 07:38:34 24 4
gpt4 key购买 nike

目前我正在使用以下cmd将数据导入elasticsearch

curl -XPOST 'localhost:9200/index/_bulk?pretty' --data-binary @required.json

ElasticSearch Bulk API

现在我正在创建一个 java 控制台应用程序,我需要在发布请求中发送此文件。我可以使用 SoapUI 来做到这一点,即附加带有标题的文件

Content-Type: text/javascript

从 SOAPUI 执行此请求成功并且数据已加载。

<小时/>

我已经研究了如何执行发布请求,并且必须遵循以下代码。所以我的问题是:

  1. 我们如何将文件附加到请求中?
  2. 如果无法附加文件,还有什么其他可能的解决方案?

    URL url = new URL("http://localhost:9200/index/_bulk/");
    HttpURLConnection httpCon = (HttpURLConnection) url.openConnection();
    httpCon.setDoOutput(true);
    httpCon.setRequestMethod("POST");
    httpCon.setRequestProperty("Content-Type", "text/javascript"); // (or text/plain)
    httpCon.setRequestProperty("Accept", "application/json");
    OutputStreamWriter out = new OutputStreamWriter(httpCon.getOutputStream());

    out.write(...filedata...); // <------ How to Put file data in output stream ?

    out.flush();
    out.close();

最佳答案

如何将文件内容写入输出

//out.write(...filedata...); // <------ How to Put file data in output stream ?

// Create a path to your file
Path path = Paths.get("D:/TEMP/bulk.json"); // <------ your file name

// Open a BufferedReader to your file - change CharSet if necessary
BufferedReader fReader = Files.newBufferedReader(path, Charset.defaultCharset());

String data = null;
// Read each line, append "\n" to it as required by Bulk API and write it to the server
while ((data = fReader.readLine()) != null) {
out.write(data + "\n"); // <------ Put each line in output stream
out.flush(); // <------ You may do this outside the loop once
}

out.close();

注意:有多种方法可以将文件内容写入输出流。我刚刚指定了一项。您可以探索其他人。

bulk.json

{ "index" : { "_index" : "test", "_type" : "string", "_id" : "10" } }
{ "field1" : "value10" }
{ "index" : { "_index" : "test", "_type" : "string", "_id" : "20" } }
{ "field1" : "value20" }
{ "index" : { "_index" : "test", "_type" : "string", "_id" : "30" } }
{ "field1" : "value30" }

测试

http://localhost:9200/test/string/10
{"_index":"test","_type":"string","_id":"10","_version":3,"found":true,"_source":{ "field1" : "value10" }}

此外,由于您的客户端是 Java,您是否考虑过使用 ElasticSearch Java 客户端 API?我不太了解,但它应该支持批量请求。查看 client.bulk(BulkRequest) 方法。

关于java - 如何通过在java中的post请求中发送文件将数据导入elasticsearch?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35018109/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com