前后端交互 gzip加密-->前端解析

今天跟后台对接一个接口,接受到一个加密的值,说是通过gzip加密,前端解码展示

下载poko.js

poko.js可至Github下载 https://github.com/nodeca/pako 

or

npm install pako

import pako from 'pako'

// 一个是加密:window.btoa(),一个是解密:window.atob()

function decode(encodedData) {

 // 先 base64编码

 // 加密:window.btoa(),解密:window.atob()

 let decodedData = window.atob(encodedData);

 // 字符串转数组 在循环返回一个 Unicode表所在位置的新数组

 let charData = decodedData.split("").map(x => x.charCodeAt(0));

 // Uint8Array 数组类型表示一个8位无符号整型数组,创建时内容被初始化为0。创建完后,可以以对象的方式或使用数组下标索引的方式引用数组中的元素。

 let binData = newUint8Array(charData);

 // 调用pako 解析

 let data = pako.inflate(binData);

 //接受 Unicode 值,然后返回字符串。

 decodedData = String.fromCharCode.apply(null, new Uint16Array(data));

 return   decodeURIComponent(escape(decodedData))

 /**

 * 演示:H4sIAAAAAAAAAFWPXQ6AIAyDL2QMavfD/S+m3bIhL1862hVQO8ehAf9gg7g4PmUABM8gDRoyegxX iUljjdhUboRivUipbPEKy0Lk4jbUvYiNrkpIG2ilrXx3vR/pWy5+nrgJlhojzjUjdP5zL5Sz+lo/ AQAA

 *

 */

}

注:decodeURIComponent(decodedData)  解析还是会有乱码 经查找资料更改为 decodeURIComponent(escape(decodedData))

functionutf8_to_b64(str){

returnwindow.btoa(unescape(encodeURIComponent(str)));

}

functionb64_to_utf8(str){

returndecodeURIComponent(escape(window.atob(str)));

}

资料借鉴:https://blog.csdn.net/abxn2002/article/details/50887594

你可能感兴趣的:(前后端交互 gzip加密-->前端解析)