在学习第一行代码第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,具体机制我还要深入学习研究。
相关网址: