gpt4 book ai didi

java - Documents4j 的 RemoteConverter 的自定义 HttpClient

转载 作者:行者123 更新时间:2023-11-30 02:56:49 24 4
gpt4 key购买 nike

我正在使用 RemoteConverter 从 jBoss Web 应用程序到一个独立服务器,该服务器构建为默认的 server-standalone 包含在 Documents4j 项目中。

在jboss内部,我有一个旧版本的所需库httpclient-4.0.1.jar和相关的httpcore-4.0.1.jar,所以我面临有很多 ClassDefNotFoundException 是由 JVM 加载的 jar 版本不同引起的。

HttpClientConnectionManager 对象存在一个特定问题,该问题在版本中尚不可用

为了避免这个问题,我想为独立服务器创建一个自定义http客户端,因为由于之前的问题,我不可能使用Jersey.

有人为该独立服务器构建了不同的客户端吗?构建自定义 RemoteClient 的规范是什么?

更新1

在嗅探工具的帮助下进行了一些分析后,我弄清楚了消息的组成,因此我刚刚结束了该服务器的自定义 HttpClient ,如下所示:

    File wordFile = new File("C:/temp/test.docx");
InputStream targetStream = new FileInputStream(wordFile);

URL url = new URL("http://localhost:9998");
HttpURLConnection conn = (HttpURLConnection) url.openConnection();
conn.setDoOutput(true);
conn.setRequestMethod("POST");
conn.setRequestProperty("Content-Type", "application/vnd.com.documents4j.any-msword");
conn.setRequestProperty("Accept", "application/pdf");
conn.setRequestProperty("Converter-Job-Priority", "1000");


OutputStream os = conn.getOutputStream();
os.write(IOUtils.toByteArray(targetStream));
os.flush();

if (conn.getResponseCode() != HttpURLConnection.HTTP_OK) {
throw new RuntimeException("Failed : HTTP error code : "
+ conn.getResponseCode());
}

BufferedReader br = new BufferedReader(new InputStreamReader(
(conn.getInputStream())));
FileWriter ostream = new FileWriter("C:/temp/test.pdf");
BufferedWriter out = new BufferedWriter(ostream);
String output;
System.out.println("Output from Server .... \n");
while ((output = br.readLine()) != null) {
System.out.println(output);
out.write(output+"\n");
}
br.close();
out.close();
os.close();
conn.disconnect();

现在我遇到了另一个问题,如果我尝试打开刚刚创建的 test.pdf 文件,它是全白色的,但页数正确。如果我使用文本编辑器打开文件并分析文件的开头和结尾,我会发现以下字符:

%PDF-1.5
%µµµµ
1 0 obj
[...]
startxref
1484122
%%EOF

这似乎是一个不错的 PDF 文件。

从 REST 服务器收到的文件还有其他用途吗?

最佳答案

在回答您的问题之前:我建议您宁愿shade然后重新实现它的依赖关系。

我可以想象您在实现自己的服务时遇到编码问题。 BufferedReader 将传入数据转换为字符数据。不按字符行读取数据,而是将其视为二进制。使用 Stream 类代替 Writer 类。这就是为什么元数据被正确处理,因为它是由字符表示的,但实际数据是非法的,因为它是二进制信息:

InputStream in = conn.getInputStream();
OutputStream out = new FileOutputStream("C:/temp/test.pdf");
byte[] buffer = new byte[1024];
int len;
while ((len = in.read(buffer)) != -1) {
out.write(buffer, 0, len);
}

关于java - Documents4j 的 RemoteConverter 的自定义 HttpClient,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37028962/

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