Android学习--自己在使用HttpConnection时遇到的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;

 

posted @   itoysk  阅读(2914)  评论(1编辑  收藏  举报
努力加载评论中...
点击右上角即可分享
微信分享提示