溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

解決nodejs中使用http請求返回值為html時亂碼的問題

發(fā)布時間:2020-08-27 03:21:26 來源:腳本之家 閱讀:283 作者:jingxian 欄目:web開發(fā)

今天用nodejs進行http請求時返回的數(shù)據(jù)是一個html文件,然后我還是按照以前解析json數(shù)據(jù)的方法。果不其然報錯了:SyntaxError: Unexpected token  in JSON at position 0

沒辦法,只好換一種方法,將接受到的Buffer對象toString,然后打印出來發(fā)現(xiàn)是亂碼。

第一感覺是編碼問題,google一下然后看官方文檔,總結(jié)三種方法:

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字符串。

如果需要使用同步的同學,請調(diào)用zlib.unzipSync(buffer); ps:表示我測試的時候報錯了。Error: unexpected end of file

好了,到這里,我的問題就完美解決了。

以上這篇解決nodejs中使用http請求返回值為html時亂碼的問題就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持億速云。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI