今天用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)是亂碼。
第一感覺是編碼問(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 一下;
然后在頭部引入
延伸閱讀
學(xué)習(xí)是年輕人改變自己的最好方式