为了保持服务器端配额内存储的数据量,我需要减少存储数据的大小,并希望能够在将其发送到服务器之前在浏览器中对字符串化的JSON进行gzip压缩。
然而,我找不到太多JavaScript实现Gzip的方法。有没有建议可以在客户端上压缩数据并将其发送?
编辑:有一个更好的 LZW 解决方案可以正确处理 Unicode 字符串,位于 http://pieroxy.net/blog/pages/lz-string/index.html(感谢评论中的 pieroxy)。
我不知道任何 gzip 实现,但是 jsolait 库(该网站似乎已经关闭)具有 LZW 压缩/解压缩函数。代码受 LGPL 许可证保护。
// LZW-compress a string
function lzw_encode(s) {
var dict = {};
var data = (s + "").split("");
var out = [];
var currChar;
var phrase = data[0];
var code = 256;
for (var i=1; i<data.length; i++) {
currChar=data[i];
if (dict[phrase + currChar] != null) {
phrase += currChar;
}
else {
out.push(phrase.length > 1 ? dict[phrase] : phrase.charCodeAt(0));
dict[phrase + currChar] = code;
code++;
phrase=currChar;
}
}
out.push(phrase.length > 1 ? dict[phrase] : phrase.charCodeAt(0));
for (var i=0; i<out.length; i++) {
out[i] = String.fromCharCode(out[i]);
}
return out.join("");
}
// Decompress an LZW-encoded string
function lzw_decode(s) {
var dict = {};
var data = (s + "").split("");
var currChar = data[0];
var oldPhrase = currChar;
var out = [currChar];
var code = 256;
var phrase;
for (var i=1; i<data.length; i++) {
var currCode = data[i].charCodeAt(0);
if (currCode < 256) {
phrase = data[i];
}
else {
phrase = dict[currCode] ? dict[currCode] : (oldPhrase + currChar);
}
out.push(phrase);
currChar = phrase.charAt(0);
dict[code] = oldPhrase + currChar;
code++;
oldPhrase = phrase;
}
return out.join("");
}
我有另外一个问题,我不想将数据编码为gzip格式,而是要解码gzip压缩的数据。因为我在浏览器之外运行JavaScript代码,所以我需要使用纯JavaScript进行解码。
我花了一些时间,但是在JSXGraph库中发现了一种读取gzipped数据的方法。
这里是我找到该库的地方:http://jsxgraph.uni-bayreuth.de/wp/2009/09/29/jsxcompressor-zlib-compressed-javascript-code/ 甚至还有一个独立的实用程序JSXCompressor可以做到这一点,并且代码是LGPL许可证。
只需在您的项目中包含jsxcompressor.js文件,然后您就能够读取基于base64编码的gzip压缩数据:
<!doctype html>
</head>
<title>Test gzip decompression page</title>
<script src="jsxcompressor.js"></script>
</head>
<body>
<script>
document.write(JXG.decompress('<?php
echo base64_encode(gzencode("Try not. Do, or do not. There is no try."));
?>'));
</script>
</html>
我知道这不是你想要的,但我还是在这里回答,因为我认为它对某些人会有帮助。
<?php..
这一部分吗?我问这个问题是因为它被传递给了 decompress
方法。 - Jus1214:16:28.512 TypeError: e.replace 不是一个函数[更多信息] jsxcompressor.min.js:19:12201
- Bluscream我们刚刚发布了pakohttps://github.com/nodeca/pako,这是将zlib移植到JavaScript的版本。我认为它现在是最快的JS实现压缩/解压缩/gzip/ungzip。另外,它采用民主的MIT许可证。Pako支持所有zlib选项,且其结果是二进制相等的。
例如:
var inflate = require('pako/lib/inflate').inflate;
var text = inflate(zipped, {to: 'string'});
我没有测试过,但有一个名为JSZip的JavaScript实现的ZIP:
我猜一种通用的客户端JavaScript压缩实现在处理时间方面会非常昂贵,而不是通过传输几个未压缩有效载荷的HTTP数据包所需的传输时间。
你有做过任何测试吗?这样可以让你了解有多少时间可以节省。我的意思是,带宽节省可能不是你追求的目标,或者说它是吗?
您可以在页面中嵌入一个每像素1个像素的Java小程序,并将其用于压缩。
它不是JavaScript,客户端需要Java运行时,但它可以满足您的需求。