zoukankan      html  css  js  c++  java
  • httpclient解析gzip网页

    请求时加上:getHC.setRequestHeader("Accept-Encoding","gzip, deflate");

    解析时

    String acceptEncoding = "";
         if(getHC.getResponseHeader("Content-Encoding")!=null)
          acceptEncoding = getHC.getResponseHeader("Content-Encoding").getValue();
         StringBuffer sb =new StringBuffer();
         log.debug("acceptEncoding:"+acceptEncoding);
         if(acceptEncoding.toLowerCase().indexOf("gzip") > -1)
         {
          //建立gzip解压工作流
          InputStream is = getHC.getResponseBodyAsStream();
          GZIPInputStream gzin = new GZIPInputStream(is);
          InputStreamReader isr = new InputStreamReader(gzin, charset); // 设置读取流的编码格式,自定义编码
          java.io.BufferedReader br = new java.io.BufferedReader(isr);
          String tempbf;
          while((tempbf=br.readLine())!=null){
           sb.append(tempbf);
           sb.append("\r\n");
          }
          isr.close();
          gzin.close();

         }
         else
         {
          InputStreamReader isr = new InputStreamReader(getHC.getResponseBodyAsStream(), charset); // 设置读取流的编码格式,自定义编码
          java.io.BufferedReader br = new java.io.BufferedReader(isr);
          String tempbf;
          while((tempbf=br.readLine())!=null){
           sb.append(tempbf);
           sb.append("\r\n");
          }
          isr.close();
         }
         getHC.abort();
         getHC.releaseConnection();
         ((SimpleHttpConnectionManager)httpClient.getHttpConnectionManager()).shutdown();

  • 相关阅读:
    基于tensorflow的简单线性回归模型
    msm8909平台JEITA配置和bat-V therm表合入
    开始点滴积累
    消息队列中间件(一)介绍
    Ubuntu18 的超详细常用软件安装
    IO通信模型(三)多路复用IO
    IO通信模型(二)同步非阻塞模式NIO(NonBlocking IO)
    IO通信模型(一)同步阻塞模式BIO(Blocking IO)
    Web笔记(二)Tomcat 使用总结
    const in C/C++
  • 原文地址:https://www.cnblogs.com/yesun/p/1323432.html
Copyright © 2011-2022 走看看