解決nodejs中使用http請求返回值為html時亂碼的問題
今天用nodejs進行http請求時返回的數(shù)據(jù)是一個html文件,然后我還是按照以前解析json數(shù)據(jù)的方法。果不其然報錯了:SyntaxError: Unexpected token in JSON at position 0
沒辦法,只好換一種方法,將接受到的Buffer對象toString,然后打印出來發(fā)現(xiàn)是亂碼。
第一感覺是編碼問題,google一下然后看官方文檔,總結三種方法:
1、toString 加編碼格式作為參數(shù)。
2、使用iconv-lite 改變編碼。
3、使用cheerio來加載html。
奈何上面三種方法都不是我錯誤的地方,然后看到cnode里面有個人有相似的問題,雖然不盡相同,但是下面回答的人中有人提到了使用gzip壓縮,收到后不解壓會導致亂碼,然后在我的請求頭中果然發(fā)現(xiàn)了gzip壓縮 = =手動捂臉。
知道了問題所在,那么解決起來就很方便了。
首先讓我們來npm install zlib 一下;
然后在頭部引入 var zlib = require('zlib');
然后查閱官方文檔,發(fā)現(xiàn)有兩種解壓方式,一種是同步,另一種是異步。
我這里就使用異步的方式了。
zlib.unzip(chunk,function(error,res){
console.log(error);
console.log(res+"");
});
這里的chunk就是我們的接受到的buffer對象,需要注意的是這個異步的callback有兩個參數(shù),第一個好像是錯誤信息,第二個才是我們需要的html字符串。
如果需要使用同步的同學,請調用zlib.unzipSync(buffer); ps:表示我測試的時候報錯了。Error: unexpected end of file
好了,到這里,我的問題就完美解決了。
以上這篇解決nodejs中使用http請求返回值為html時亂碼的問題就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
AngularJs根據(jù)訪問的頁面動態(tài)加載Controller的解決方案
這篇文章主要介紹了AngularJs根據(jù)訪問的頁面動態(tài)加載Controller的解決方案,需要的朋友可以參考下2015-02-02
Angular指令封裝jQuery日期時間插件datetimepicker實現(xiàn)雙向綁定示例
這篇文章主要介紹了Angular指令封裝jQuery日期時間插件datetimepicker實現(xiàn)雙向綁定示例,具有一定的參考價值,有興趣的可以了解一下。2017-01-01
angularJs提交文本框數(shù)據(jù)到后臺的方法
今天小編就為大家分享一篇angularJs提交文本框數(shù)據(jù)到后臺的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-10-10
Angular實現(xiàn)的內(nèi)置過濾器orderBy排序與模糊查詢功能示例
這篇文章主要介紹了Angular實現(xiàn)的內(nèi)置過濾器orderBy排序與模糊查詢功能,涉及AngularJS過濾器、排序及字符串遍歷、查詢等相關操作技巧,需要的朋友可以參考下2017-12-12
AngularJS中的$parse服務與$eval服務用法實例
這篇文章主要介紹了AngularJS中的$parse服務與$eval服務用法,結合實例形式分析了AngularJS中$parse服務與$eval服務的功能、使用方法與相關注意事項,需要的朋友可以參考下2023-05-05

