其實很多時候我們在做http請求資料返回的時候經常會莫名發現會出現亂碼,大部分時候我們都覺得是編碼不對造成的。
一般情況下正常我們預設都是作個很簡單的操作,直接使用utf-8編碼基本問題就搞定了
基本問題就ok了,但有時候卻並不一定,比如如果事實上編碼並不是這樣呢?
我們就需要去判斷當前正確編碼方式,來確定
根據當前返回的型別正確的編碼方式來讀對應的流即可解決問題。
but 有時候卻並不一定是編碼造成的。。。
比如:如果使用了壓縮呢???
假如在header頭中有壓縮呢? 比如:我們使用了gzip
這時候就變了,我們不能再使用普通的
這種方式了,而是應該使用gzip的流的方式
當然還有別的header的設定,比如transencoding等等,所以我們做這種資料請求的時候出現亂碼不用慌,細心去分析header頭中返回的資訊,根據header中的相關設定作相關處理。
順便說下本次其實也是在做乙個天氣預報的實驗中發現了該亂碼現象,
預設在瀏覽器中我們看到
在多種瀏覽器中返回均是亂碼,用ie11開啟也是,但右鍵更改編碼為utf-8後正常
but我們程式更改為utf-8依然不行啊。。。
當我們採用預設請求方式時,使用utf-8
結果為:
悲催啊。。。
加斷點,檢視response中相關資訊,我們看到對應的header中內容編碼方式為gzip方式。。。
直接修改這部分流的讀取方式如下:
返回結果為:
結果正常了。。。所以面對這種亂碼問題應該細心去查請求和響應頭和內容中的各種資訊。
以此小經驗作個小記錄
關於Http請求後返回json亂碼的問題
其實很多時候我們在做http請求資料返回的時候經常會莫名發現會出現亂碼,大部分時候我們都覺得是編碼不對造成的。一般情況下正常我們預設都是作個很簡單的操作,直接使用utf 8編碼基本問題就搞定了 基本問題就ok了,但有時候卻並不一定,比如如果事實上編碼並不是這樣呢?我們就需要去判斷當前正確編碼方式,來...
關於Http請求後返回json亂碼的問題
其實很多時候我們在做http請求資料返回的時候經常會莫名發現會出現亂碼,大部分時候我們都覺得是編碼不對造成的。一般情況下正常我們預設都是作個很簡單的操作,直接使用utf 8編碼基本問題就搞定了 基本問題就ok了,但有時候卻並不一定,比如如果事實上編碼並不是這樣呢?我們就需要去判斷當前正確編碼方式,來...
關於Http請求後返回json亂碼的問題
其實很多時候我們在做http請求資料返回的時候經常會莫名發現會出現亂碼,大部分時候我們都覺得是編碼不對造成的。一般情況下正常我們預設都是作個很簡單的操作,直接使用utf 8編碼基本問題就搞定了 基本問題就ok了,但有時候卻並不一定,比如如果事實上編碼並不是這樣呢?我們就需要去判斷當前正確編碼方式,來...