Welcome to ShenZhenJia Knowledge Sharing Community for programmer and developer-Open, Learning and Share
menu search
person
Welcome To Ask or Share your Answers For Others

Categories

let axios = require('axios');
let iconv = require('iconv-lite');

axios({
    url : 'xxxxx/gbk.html',
    responseType : 'stream' //将数据转化为流返回
})
.then(res=>{
    //此时的res.data 则为stream
    let chunks = [];
    res.data.on('data',chunk=>{
        chunks.push(chunk);
    });
    res.data.on('end',()=>{
        let buffer = Buffer.concat(chunks);
        //通过iconv来进行转化。
        let str = iconv.decode(buffer,'gbk');
        console.log(str);
        // 想将 str 返回出去
    })
})
// 在这里接收 str
const res = await axios()

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
thumb_up_alt 0 like thumb_down_alt 0 dislike
4.2k views
Welcome To Ask or Share your Answers For Others

1 Answer

包装个 Promise 不就好了?

axios({
    url : 'xxxxx/gbk.html',
    responseType : 'stream' // 将数据转化为流返回
})
.then(res => {
    return new Promise((resolve, reject) => {
        // 此时的res.data 则为stream
        let chunks = [];
        res.data.on('data',chunk=>{
            chunks.push(chunk);
        });
        res.data.on('end',()=>{
            let buffer = Buffer.concat(chunks);
            // 通过iconv来进行转化。
            let str = iconv.decode(buffer,'gbk');
            // 将 str 返回出去
            resolve(str);
        });
    });
})

// 在这里接收 str
const res = await axios();

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
thumb_up_alt 0 like thumb_down_alt 0 dislike
Welcome to ShenZhenJia Knowledge Sharing Community for programmer and developer-Open, Learning and Share
...