作者:zxsaqw | 来源:互联网 | 2023-10-12 18:09
在学习第一行代码第14章酷欧天气的时候,HttpUtil类中的sendHttpRequest方法发出请求,然后返回响应信息,但是出现了EOFException异常,代码如下:这段代
在学习第一行代码第14章酷欧天气的时候,HttpUtil类中的sendHttpRequest方法发出请求,然后返回响应信息,但是出现了EOFException异常,代码如下:
HttpURLConnection cOnnection= null;
try {
URL url = new URL(address);
connection = (HttpURLConnection) url.openConnection();
connection.setRequestMethod("GET");
connection.setConnectTimeout(8000);
connection.setReadTimeout(8000);
InputStream in = connection.getInputStream();
BufferedReader reader = new BufferedReader(new InputStreamReader(in));
StringBuilder response = new StringBuilder();
String line;
while ((line = reader.readLine()) != null) {
response.append(line);
}
} catch (Exception e) {
Log.e("HttpUtil",e.toString());
} finally {
if (connection != null) {
connection.disconnect();
}
}
这段代码,对于查找省份和城市,均工作正常,但是当显示天气信息的时候,偶尔有很小的几率正常显示,但是大多数时候都会Catch到异常信息,
while ((line = reader.readLine()) != null) {
上面一行代码会报错,Logcat打印显示 java.io.EOFException,意思就是不知道流的末尾,当到达末尾的时候,自然抛出了此异常。百思不得其解,然后Google,百度各种搜索,但是搜索出来的答案并不有效,其中一个网上提供的解决方案是:
connection.setRequestProperty("Content-type", "application/x-java-serialized-object");
但是试了加了这句无效,无奈,继续搜索解决方法,终于找到了些解决方法。
通过查看《第一行代码中》最后返回天气信息的网址,发现响应头中的Content-Encoding为gzip:
所以我猜测原因就在于此,根据Google搜索出来的原因,是因为 当 响应的InputStream 是 GZIPInputStream时,会造成 HTTP HEAD 的冲突,此处应该是个Bug,原因可以参考以下网址:
https://code.google.com/p/android/issues/detail?id=24672
解决此问题的方案就是在 connection.getInputStream();之前设置 RequestProperty,代码如下:
......
//此处设置避免出现EOFException
connection.setRequestProperty( "Accept-Encoding", "" );
InputStream in = connection.getInputStream();
.......
这样就可以解决 之前我遇到的 EOFException,具体机制我还要深入学习研究。
相关网址:
https://code.google.com/p/android/issues/detail?id=24672;
http://stackoverflow.com/questions/17638398/androids-httpurlconnection-throws-eofexception-on-head-requests;
Android学习--自己在使用HttpConnection时遇到的EOFException