Java 用于Documents4j远程转换器的自定义HttpClient
我正在使用一个从jBoss web应用程序到独立服务器的Java 用于Documents4j远程转换器的自定义HttpClient,java,jersey,httpclient,documents4j,Java,Jersey,Httpclient,Documents4j,我正在使用一个从jBoss web应用程序到独立服务器的RemoteConverter,作为documents4j项目中包含的默认ServerStandalone构建 在jboss内部,我有一个旧版本的必需库httpclient-4.0.1.jar和相关的httpcore-4.0.1.jar,因此我面临许多由JVM加载的jar的不同版本引起的ClassDefNotFoundException HttpClientConnectionManager对象存在一个特定问题,该问题在版本中尚不可用 为了
RemoteConverter
,作为documents4j项目中包含的默认ServerStandalone
构建
在jboss内部,我有一个旧版本的必需库httpclient-4.0.1.jar
和相关的httpcore-4.0.1.jar
,因此我面临许多由JVM加载的jar的不同版本引起的ClassDefNotFoundException
HttpClientConnectionManager
对象存在一个特定问题,该问题在版本中尚不可用
为了避免这个问题,我想为独立服务器
创建一个自定义http客户端,因为由于前面的问题,我不可能使用Jersey
是否有人为该独立服务器
构建了不同的客户端?构建自定义远程客户端的规范是什么
更新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服务器接收到的文件是否与此有关 在回答您的问题之前:我建议您放弃依赖关系,然后重新实现它
我可以想象,在实现自己的服务时,您将面临编码问题。BufferedReader
将传入数据转换为字符数据。不要按字符行读取数据,而是将其视为二进制。使用流类代替编写器类。这就是为什么元数据被正确处理,因为它由字符表示,但实际数据是非法的,因为它是二进制信息:
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);
}