前端代码
decode(encodedData) {
var strData = atob(encodedData)
var charData = strData.split('').map(function(x) {
return x.charCodeAt(0)
})
var binData = new Uint8Array(charData)
var data = pako.inflate(binData)
strData = this.Utf8ArrayToStr(data)
return strData
},
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:
out += String.fromCharCode(c)
break
case 12:
case 13:
char2 = array[i++]
out += String.fromCharCode(((c & 0x1f) << 6) | (char2 & 0x3f))
break
case 14:
char2 = array[i++]
char3 = array[i++]
out += String.fromCharCode(((c & 0x0f) << 12) | ((char2 & 0x3f) << 6) | ((char3 & 0x3f) << 0))
break
}
}
return out
}
- Utf8ArrayToStr 这个方法和网上很多的 Utf8Array 不同在于,这里还解决了URL中文乱码的问题噢~
后端代码
byte[] gzipService = ZipUtil.gzip((JSON.toJSONString(service)), "UTF-8");
return ResultUtil.buildSuccByData(service);
注意事项
- 需要用 GZIP 必须是 GET 请求,以后这中返回数据量大的接口,只要不涉及到敏感信息,务必使用GET请求,这样可以省好多事。