欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java使用GZIP壓縮導致HTTP請求返回亂碼問題解決

 更新時間:2022年06月17日 14:55:23   作者:yuan  
這篇文章主要為大家介紹了Java壓縮GZIP導致HTTP請求返回亂碼問題解決,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪

原因

用Java調用雪球的API,結果返回的是亂碼,一番研究后發(fā)現(xiàn)是因為返回的數(shù)據(jù)使用了GZIP壓縮,需要先解壓才能得到正確數(shù)據(jù)。

思路

使用了GZIP壓縮的數(shù)據(jù)在響應頭里會有一項名為content-encoding的參數(shù),值為gzip。

Java中可以使用.getHeaderField()讀取響應頭的參數(shù)。

如果沒有這項參數(shù),會返回null。

解決方法

用.getHeaderField("content-encoding")讀取content-encoding參數(shù)的值。

如果值不為空,通過值判斷是否用了gzip壓縮。

使用了gzip就解壓,沒用就不處理。

代碼

關鍵部分

// 獲取響應頭content-encoding數(shù)據(jù),如果是gzip就解壓(以后可能要改成部分對比.contains()而不是全部對比)
String contentEncoding = conn.getHeaderField("content-encoding");
if((contentEncoding != null)&&(contentEncoding.equals("gzip"))){
    is = new GZIPInputStream(conn.getInputStream());
}else{
    is = conn.getInputStream();
}

完整代碼

部分地方需要按需修改

import java.io.*;
import java.net.HttpURLConnection;
import java.net.MalformedURLException;
import java.net.URL;
import java.util.zip.GZIPInputStream;
public class HttpURLConnectionTools {
    public String doPost(String URL, String jsonStr) {
        OutputStreamWriter out = null;
        BufferedReader in = null;
        InputStream is = null;
        StringBuilder result = new StringBuilder();
        HttpURLConnection conn = null;
        try {
            java.net.URL url = new URL(URL);
            conn = (HttpURLConnection) url.openConnection();
            conn.setRequestMethod("POST");
            // 發(fā)送POST請求必須設置為true
            conn.setDoOutput(true);
            conn.setDoInput(true);
            // 設置連接超時時間和讀取超時時間
            conn.setConnectTimeout(30000);
            conn.setReadTimeout(10000);
            conn.setRequestProperty("Content-Type", "application/json");
            conn.setRequestProperty("Accept", "application/json");
            // 獲取輸出流
            out = new OutputStreamWriter(conn.getOutputStream());
            out.write(jsonStr);
            out.flush();
            out.close();
            // 取得輸入流,并使用Reader讀取
            if (200 == conn.getResponseCode()) {
                // 獲取響應頭content-encoding數(shù)據(jù),如果是gzip就解壓(以后可能要改成部分對比.contains()而不是全部對比)
                String contentEncoding = conn.getHeaderField("content-encoding");
                if((contentEncoding != null)&&(contentEncoding.equals("gzip"))){
                    is = new GZIPInputStream(conn.getInputStream());
                }else{
                    is = conn.getInputStream();
                }
                in = new BufferedReader(new InputStreamReader(is, "UTF-8"));
                String line;
                while ((line = in.readLine()) != null) {
                    result.append(line);
                    System.out.println(line);
                }
            } else {
                System.out.println("ResponseCode is an error code:" + conn.getResponseCode());
            }
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            try {
                if (out != null) {
                    out.close();
                }
                if (in != null) {
                    in.close();
                }
            } catch (IOException ioe) {
                ioe.printStackTrace();
            }
        }
        return result.toString();
    }
    public String doGet(String URL) {
        HttpURLConnection conn = null;
        InputStream is = null;
        BufferedReader br = null;
        StringBuilder result = new StringBuilder();
        try {
            // 創(chuàng)建遠程url連接對象
            URL url = new URL(URL);
            // 通過遠程url連接對象打開一個連接,強轉成HTTPURLConnection類
            conn = (HttpURLConnection) url.openConnection();
            conn.setRequestMethod("GET");
            // 設置連接超時時間和讀取超時時間
            conn.setConnectTimeout(15000);
            conn.setReadTimeout(60000);
            conn.setRequestProperty("accept-encoding","gzip, deflate, br");
            conn.setRequestProperty("User-agent","Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/98.0.4758.102 Safari/537.36 Edg/98.0.1108.62");
            // 發(fā)送請求
            conn.connect();
            // 通過conn取得輸入流,并使用Reader讀取
            if (200 == conn.getResponseCode()) {
                // 獲取響應頭content-encoding數(shù)據(jù),如果是gzip就解壓(以后可能要改成部分對比.contains()而不是全部對比)
                String contentEncoding = conn.getHeaderField("content-encoding");
                if((contentEncoding != null)&&(contentEncoding.equals("gzip"))){
                    is = new GZIPInputStream(conn.getInputStream());
                }else{
                    is = conn.getInputStream();
                }
                br = new BufferedReader(new InputStreamReader(is, "UTF-8"));
                String line;
                while ((line = br.readLine()) != null) {
                    result.append(line);
                    System.out.println(line);
                }
            } else {
                System.out.println("ResponseCode is an error code:" + conn.getResponseCode());
            }
        } catch (MalformedURLException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            try {
                if (br != null) {
                    br.close();
                }
                if (is != null) {
                    is.close();
                }
            } catch (IOException ioe) {
                ioe.printStackTrace();
            }
            conn.disconnect();
        }
        return result.toString();
    }
    public static void main(String[] args) {
        System.out.println(new HttpURLConnectionTools().doGet("https://api.66mz8.com/api/weather.php?location=%E5%8C%97%E4%BA%AC"));
        System.out.println(new HttpURLConnectionTools().doGet("http://api.wpbom.com/api/neran.php"));
    }
}

以上就是Java使用GZIP壓縮導致HTTP請求返回亂碼問題解決的詳細內容,更多關于Java GZIP壓縮HTTP返回亂碼的資料請關注腳本之家其它相關文章!

相關文章

  • Spring中的父子容器原理解析

    Spring中的父子容器原理解析

    這篇文章主要為大家介紹了Spring中的父子容器原理解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-07-07
  • 簡單的用java實現(xiàn)讀/寫文本文件的示例

    簡單的用java實現(xiàn)讀/寫文本文件的示例

    同時也展示了如果從輸入流中讀出來內容寫入輸出流中(僅限文本流) 三個例子可以獨立存在,所以根據(jù)需要只看其中一個就行了。
    2008-07-07
  • Intellj Idea中的maven工程Java文件顏色不對,未被識別的解決

    Intellj Idea中的maven工程Java文件顏色不對,未被識別的解決

    這篇文章主要介紹了Intellj Idea中的maven工程Java文件顏色不對,未被識別的解決,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-08-08
  • idea如何生成springboot單元測試用例

    idea如何生成springboot單元測試用例

    這篇文章主要介紹了idea生成springboot單元測試用例,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-08-08
  • spring boot 枚舉使用的坑整理

    spring boot 枚舉使用的坑整理

    在本篇文章里我們給大家整理了關于spring boot 枚舉使用的坑以及相關知識點內容,需要的朋友們學習下。
    2019-08-08
  • 詳解Java的按位操作符

    詳解Java的按位操作符

    Java的位操作符用來操作整數(shù)基本數(shù)據(jù)類型中的單個“比特”(bit),即代進制位。下面通過本文給大家分享Java的按位操作符,感興趣的朋友一起看看吧
    2017-09-09
  • Maven直接依賴、間接依賴、依賴沖突、依賴仲裁的實現(xiàn)

    Maven直接依賴、間接依賴、依賴沖突、依賴仲裁的實現(xiàn)

    本文主要介紹了Maven直接依賴、間接依賴、依賴沖突、依賴仲裁的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-09-09
  • SpringBoot中實現(xiàn)Redis緩存預熱

    SpringBoot中實現(xiàn)Redis緩存預熱

    緩存預熱是一種在系統(tǒng)啟動后,但在實際使用前將數(shù)據(jù)加載到緩存中的技術,本文主要來和大家一起探討如何在Spring Boot應用程序中實現(xiàn)Redis緩存預熱,以確保系統(tǒng)在處理請求前就已經處于最佳狀態(tài),感興趣的可以了解下
    2023-11-11
  • 深入淺析Netty 在 Dubbo 中是如何應用的

    深入淺析Netty 在 Dubbo 中是如何應用的

    國內知名框架 Dubbo 底層使用的是 Netty 作為網絡通信,那么內部到底是如何使用的呢?今天通過本文給大家詳細講解,對Netty 在 Dubbo中應用相關知識感興趣的朋友跟隨小編一起看看吧
    2020-05-05
  • springboot 日志彩色消失的2種解決方案

    springboot 日志彩色消失的2種解決方案

    這篇文章主要介紹了springboot 日志彩色消失的2種解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-07-07

最新評論