解決nodejs中使用http請(qǐng)求返回值為html時(shí)亂碼的問(wèn)題
今天用nodejs進(jìn)行http請(qǐng)求時(shí)返回的數(shù)據(jù)是一個(gè)html文件,然后我還是按照以前解析json數(shù)據(jù)的方法。果不其然報(bào)錯(cuò)了:SyntaxError: Unexpected token in JSON at position 0
沒(méi)辦法,只好換一種方法,將接受到的Buffer對(duì)象toString,然后打印出來(lái)發(fā)現(xiàn)是亂碼。
第一感覺(jué)是編碼問(wèn)題,google一下然后看官方文檔,總結(jié)三種方法:
1、toString 加編碼格式作為參數(shù)。
2、使用iconv-lite 改變編碼。
3、使用cheerio來(lái)加載html。
奈何上面三種方法都不是我錯(cuò)誤的地方,然后看到cnode里面有個(gè)人有相似的問(wèn)題,雖然不盡相同,但是下面回答的人中有人提到了使用gzip壓縮,收到后不解壓會(huì)導(dǎo)致亂碼,然后在我的請(qǐng)求頭中果然發(fā)現(xiàn)了gzip壓縮 = =手動(dòng)捂臉。
知道了問(wèn)題所在,那么解決起來(lái)就很方便了。
首先讓我們來(lái)npm install zlib 一下;
然后在頭部引入 var zlib = require('zlib');
然后查閱官方文檔,發(fā)現(xiàn)有兩種解壓方式,一種是同步,另一種是異步。
我這里就使用異步的方式了。
zlib.unzip(chunk,function(error,res){ console.log(error); console.log(res+""); });
這里的chunk就是我們的接受到的buffer對(duì)象,需要注意的是這個(gè)異步的callback有兩個(gè)參數(shù),第一個(gè)好像是錯(cuò)誤信息,第二個(gè)才是我們需要的html字符串。
如果需要使用同步的同學(xué),請(qǐng)調(diào)用zlib.unzipSync(buffer); ps:表示我測(cè)試的時(shí)候報(bào)錯(cuò)了。Error: unexpected end of file
好了,到這里,我的問(wèn)題就完美解決了。
以上這篇解決nodejs中使用http請(qǐng)求返回值為html時(shí)亂碼的問(wèn)題就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
AngularJS實(shí)現(xiàn)按鈕提示與點(diǎn)擊變色效果
這篇文章給大家介紹了如何利用AngularJS實(shí)現(xiàn)按鈕提示與點(diǎn)擊變色的效果,文中提供了實(shí)例代碼,對(duì)大家學(xué)習(xí)AngularJS具有一定的參考借鑒價(jià)值,下面來(lái)一起看看吧。2016-09-09使用AngularJS創(chuàng)建單頁(yè)應(yīng)用的編程指引
這篇文章主要介紹了使用AngularJS創(chuàng)建單頁(yè)應(yīng)用的編程指引,AngularJS是一款高人氣的JavaScript庫(kù),需要的朋友可以參考下2015-06-06AngularJS 中使用Swiper制作滾動(dòng)圖不能滑動(dòng)的解決方法
Swiper是目前較為流行的移動(dòng)端觸摸滑動(dòng)插件,因?yàn)槠浜?jiǎn)單好用易上手,受到很多前端開(kāi)發(fā)者的歡迎。這篇文章主要介紹了AngularJS 中使用Swiper制作滾動(dòng)圖不能滑動(dòng)的解決方法,需要的朋友可以參考下2016-11-11在 Angular 中使用 ViewChild 訪問(wèn)子組件、指令或 D
這篇文章主要介紹了如何在 Angular 中使用 ViewChild 來(lái)訪問(wèn)子組件、指令或 DOM 元素,在本教程中,您使用了 ViewChild 來(lái)從父組件類中訪問(wèn)指令、子組件和 DOM 元素,需要的朋友可以參考下2024-08-08AngularJs bootstrap搭載前臺(tái)框架——準(zhǔn)備工作
本文主要介紹AngularJs bootstrap搭載前臺(tái)框架,這里對(duì)Bootstrap 搭載環(huán)境,及注意事項(xiàng)做了講解,有需要的小伙伴可以參考下2016-09-09Angular+ionic實(shí)現(xiàn)折疊展開(kāi)效果的示例代碼
這篇文章主要介紹了Angular+ionic實(shí)現(xiàn)折疊展開(kāi)效果,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-07-07@angular前端項(xiàng)目代碼優(yōu)化之構(gòu)建Api Tree的方法
這篇文章主要介紹了@angular前端項(xiàng)目代碼優(yōu)化之構(gòu)建Api Tree的方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-12-12基于AngularJs select綁定數(shù)字類型的問(wèn)題
今天小編就為大家分享一篇基于AngularJs select綁定數(shù)字類型的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-10-10