今天用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 一下;

然后在頭部引入 

網(wǎng)友評(píng)論