我试着四处寻找类似的问题,但找不到类似我的问题的任何解决方案: 我使用下面的一段代码从HttpUrlConnection中读取:
public static BufferedReader getConnectionReader(HttpURLConnection con, String url)
throws Exception {
con = (HttpURLConnection) new URL(url).openConnection();
con.connect();
if (cm != null) {
cm.storeCookies(con);
}
if (con.getHeaderField(“Content-Encoding”) != null
&& con.getHeaderField(“Content-Encoding”).equalsIgnoreCase(“gzip”)) {
return new BufferedReader(new InputStreamReader(new GZIPInputStream(con.getInputStream())));
} else
return new BufferedReader(new InputStreamReader(con.getInputStream()));
}
阅读按以下方式进行:
HttpURLConnection con = null;
reader = Utils.getConnectionReader(con, “http://www.site.com/page.html”);
String line = null;
while ((line = reader.readLine()) != null) {
log.info(line);
}
有时我会遇到上述例外情况:
java.io.EOFException: Unexpected end of ZLIB input stream
当我可以的时候,我发现了这个异常并且重试了操作 - 成功了。 问题是我不知道是什么导致这个异常弹出。 它发生得非常随机。 我想相信这是一个网络问题。 任何人都找到了解决这个问题的方法吗? 谢谢!!
您使用的方法不太适合像GZip这样的二进制格式,我假设您只是为了测试而这样做?除了那个以及HTTPURLConnection的错误之外,代码中没有太多可能导致问题的原因。我建议使用字节缓冲区交换进行读取,至少要将其作为可能的错误来源消除。