Vue-pako gizp解压,中文乱码解决

1 篇文章 0 订阅

项目中后端返回数据为加密的,需要gizp解压,发现可以使用pako来进行解压

npm install pako  // 这里进行下载

在你需要使用的页面或者全局导入

import pako from 'pako'  

网上搜到的方法都是复制粘贴基本上都是这样使用的

unzip(response.data)
function unzip(b64Data) {
    var strData = atob(b64Data)
    var charData = strData.split('').map(function(x) { return x.charCodeAt(0) })
    var binData = new Uint8Array(charData)
    var data = pako.inflate(binData) 
    strData = String.fromCharCode.apply(null, new Uint16Array(data))
    response.data = JSON.parse(strData);
    //  解压出来的数据中,中文全是乱码,没法渲染页面
}

我发现解压出来的中文全是乱码,开始以为是pako不行,去寻找其它方法,发现不怎么好实现,自己就进行一步一步的打印和调试,发现问题根本没有出在pako上,而是Uint8Array 这出的问题,需要再处理一次 ,直接开始上代码

unzip(response.data)
function unzip(b64Data) {
    var strData = atob(b64Data)
    var charData = strData.split('').map(function(x) { return x.charCodeAt(0) })
    var binData = new Uint8Array(charData)
    var data = pako.inflate(binData)   
    // 这次我们只是需要将代码转换到这一步,再调用下面的函数就可以了,对比上面少了两步
    Utf8ArrayToStr(data); 
    //  执行这步再调用函数将数据处理一次 就不会出现乱码的情况
}

再执行第二步的处理

function Utf8ArrayToStr(array) {
    var out, i, len, c;
    var char2, char3;

    out = "";
    len = array.length;
    i = 0;
    while(i < len) {
    c = array[i++];
    switch(c >> 4)
    { 
    case 0: case 1: case 2: case 3: case 4: case 5: case 6: case 7:
        // 0xxxxxxx
        out += String.fromCharCode(c);
        break;
    case 12: case 13:
        // 110x xxxx   10xx xxxx
        char2 = array[i++];
        out += String.fromCharCode(((c & 0x1F) << 6) | (char2 & 0x3F));
        break;
    case 14:
        // 1110 xxxx  10xx xxxx  10xx xxxx
        char2 = array[i++];
        char3 = array[i++];
        out += String.fromCharCode(((c & 0x0F) << 12) |
                    ((char2 & 0x3F) << 6) |
                    ((char3 & 0x3F) << 0));
        break;
    }
    }
    response.data = JSON.parse(out);
    console.log(JSON.parse(out));
}

然后就完美解决了

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值