- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我想在 Javascript 中实现部分 gzip 解压缩,即逐 block 膨胀 gzip。类似于 Linux 中的“zcat file.gz | head”。我正在寻找一个好的伪代码。
解压部分gzip的好处是:
根据 this ,一旦我们超过了 gzip 文件头的几个字节,我们就在“压缩 block ”上,我们可以膨胀自己(例如,使用 this inflate algorithm )。
我试过膨胀压缩 block 的几个前字节(即第一个 block ,任何 block 大小),它成功了!但是,当我拿第二个/第三个 block 时,它没有用。看起来 gzip-inflate 算法在 block 膨胀之前需要几个字节。
问题:确定要扩充/解压缩的 gzip block 的开始和停止字节位置的正确方法是什么?
更新:
[31,139,8,8,222,44,65,84,0,3,118,101,114,97,46,116,120,116,0,172,92,217,114,227,58,140,125,191,95,49,85,19,219,241,110,237,187,68,136,73,232,84,205,211,20,223,231,255,255,98,136,133,178,72,185,251,206,195,168,59,137,183,116,17,34,128,115,112,0,182,250,254,239,255,126,164,69,94,21,183,228,63,126,255,43,73,255,167,72,154,172,77,219,164,77,210,44,107,218,228,145,36,255,153,220,211,127,192,106,208,198,90,99,140,213,218,90,109,141,198,63,214,128,6,0,99,232,53,247,22,224,107,248,142,123,205,253,112,95,248,171,198,0,255,138,123,170,255,57,255,243,252,253,253,125,126,253,254,206,239,175,113,134,89,254,42,112,223,213,172,148,2,247,165,234,94,241,149,224,19,122,241,31,245,178,34,141,173,200,243,226,141,21,90,203,114,44,184,7,110,177,238,57,91,129,230,209,130,181,51,140,22,108,0,112,217,238,85,67,230,186,63,248,25,180,194,25,241,107,12,89,1,193,250,225,245,0,196,14,103,3,208,37,235,87,131,252,44,221,87,54,212,107,43,178,216,138,186,201,82,180,34,13,172,176,160,105,43,220,98,241,31,182,180,104,90,178,123,203,173,148,63,129,47,210,142,128,230,109,113,191,227,126,11,47,103,14,90,97,126,233,114,235,155,112,161,19,200,210,213,200,183,95,205,115,79,207,1,23,13,170,27,217,136,81,165,170,115,134,92,200,20,128,75,122,94,91,145,199,86,84,69,134,70,84,225,86,0,222,95,116,34,205,27,129,14,131,94,130,15,12,26,133,159,68,107,12,25,73,59,65,246,88,254,77,247,174,51,98,248,50,95,198,124,27,190,199,48,184,175,227,4,189,226,91,78,223,239,106,192,187,15,227,212,3,140,254,229,82,85,227,216,186,231,106,68,51,218,161,237,215,70,20,145,17,89,145,21,206,136,52,244,39,203,222,129,222,174,113,15,240,66,199,210,228,92,24,52,228,105,120,239,105,15,208,106,247,58,217,109,157,55,97,96,97,84,60,201,157,126,213,250,154,82,247,109,55,29,31,147,114,247,187,169,6,188,231,170,234,219,214,133,66,62,14,109,94,214,197,227,114,169,93,104,220,149,122,212,215];
上面是我的示例的二进制字符串数组。下面是标题:
[31,139,8,8,222,44,65,84,0,3,118,101,114,97,46,116,120,116,0]
任何以 172 开头的子字符串(紧跟在 header 之后)都可以很好地解压缩/膨胀。但是当子字符串不是来自 172 时,我在解压/膨胀时什么也得不到。也许要膨胀的字符串必须确实来自 172 位置?
最佳答案
您不能从压缩流的中间开始解压缩。至少在之前至少对整个流进行一次解压缩并为随机访问构建索引的情况下是这样。
首先,deflate 格式本质上是串行的。压缩部分是通过查找与先前字符串匹配的字符串来实现的。匹配项可能在您开始之前引用,因此您不知道未压缩的数据是什么。更重要的是,匹配的内容可能本身就是一个匹配项,并且匹配它之前的内容,一直回到文件的开头。
其次,deflate 格式本质上是串行的。它是一种由可变位数的代码构成的格式,没有标记来告诉您代码或 block 或任何内容的开始位置。仅通过查看字节序列中间的某处,无法知道放气 block 从哪里开始。了解 block 从何处开始的唯一方法是解码从压缩流开头开始的所有代码。
为了构建随机访问索引,您需要先解压缩整个内容,然后 a) 保存每个 block 开头的位位置,以及 b) 在每个 block 中保存之前的 32K 未压缩数据点以满足 block 中出现的匹配项(32K 是匹配项的最大距离)。这是一个 example of such code .
没有办法从你以前从未见过的压缩流的中间开始解压缩。
关于javascript - 膨胀/解压缩部分 gzip 的算法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26528004/
我正在尝试创建有效的 gzip 文件(可以使用标准 Linux gzip 解压缩),其中的数据使用 DEFLATE 算法和静态/预设字典编码。 我已阅读 DEFLATE 的两个规范和 gzip ,而且
我刚刚搜索了gzip和 Deflate ,并发现 Deflate 更好。 GZip or Deflate for HTTP compression Why use deflate instead of
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 要求提供代码的问题必须表现出对所解决问题的最低限度的了解。包括尝试的解决方案、为什么它们不起作用以及预期结果
我一直在寻找 Gzip 是否支持多部分文件压缩。 From what I have seen so far it does not, but how come 7z allows multipart
我可以连接两个已经 gzip 的文件(使用 gzip)然后用枪压缩它们吗? 截至今天,我从远程服务器下载 gzip 压缩文件,单独对其进行 gunzip,然后将它们合并。 希望通过合并 gzipped
我正在创建两个 gzip 文件,一个只包含一个 gzip 成员,而第二个包含 2 个 gzip 成员(两个文件连接成一个 gzip 文件)。 当我尝试通过网络服务器下载此文件时,chrome 会很好地
当我对文件夹进行去皮重和 gzip 压缩时,每次我都会得到不同的文件大小。 目录内容不变,没有变化。压缩后的文件大小变化 20 到 100 字节。这是正常行为吗? 我的数据会受到影响吗? 谢谢 最佳答
比方说 file.txt.gz有 2GB,我想看到最后 100 行左右。 zcat
我一直听说对您的网站进行 gzip 压缩是加快交付速度的良好做法。我的网站总体负载非常大,我还应该研究 gzip 吗?我还了解了使用 gzip 的缺点,例如解压缩内容以便浏览器显示所需的时间。这是真的
下载 jQuery 的生产副本时,链接旁边显示该文件为 32K Minified & Gzipped。我得到了 Minified,但是 Gzipped 是什么意思? 它是否被网络服务器压缩,如 Apa
我的网站很高兴根据以下内容进行 Gzip 压缩: http://www.gidnetwork.com/tools/gzip-test.php 但是,当我通过 Yslow 运行它时,我得到了 Gzip
我使用命令 tar 一组文件:tar -czvf file.tar.gz file/ 然后复制到 USB(ext4 格式),我检查了我可以解压它。重装系统后,挂载usb时发生了一些错误,我执行fsck
我有一个提供小部件的网络服务。为了可扩展性,我想在 Amazon S3 上保留 js 文件的 gzip 版本。问题是不能接受 gzip 文件的浏览器将不会被提供。 任何人都知道我在哪里可以找到统计数据
我正在使用 Chrome 和 Firefox 下的 Yslow 工具查看我的开发站点,其中一项建议是我对适当的内容进行 gzip。作为起点,我刚刚在我的 [/] 配置中添加了“tools.gzip.o
我正在开发一个网站,我正在使用 gzip.exe 来预压缩 css 和 js 文件(只有 1 个 css 文件从 4.53 KB 到 1.50 KB,还有一个 js 文件包含 jquery 和一些来自
我们必须使用什么类型的响应监听器来处理 Android Volley 的 gzip 响应? 如果使用 String 监听器,则响应似乎会丢失其编码。 你如何使用 Volley 处理 gzip 响应?
我用 Fiddler调试我的应用程序。每当响应被服务器压缩,而不是解压缩响应时,Fiddler 显示不可读的二进制数据: /* Response to my request (POST) */ HTT
我通常使用tar zcvf压缩并使用tar zxvf解压缩(由于习惯使用gzip)。 我最近购买了一个具有超线程功能的四核 CPU,因此我有 8 个逻辑核心,并且我注意到许多核心在压缩/解压缩期间未使
我正在使用 Google Cloud Storage 控制台上传文件。我没有使用任何命令行工具。 我想在元数据中将 Content-Encoding 设置为 gzip(-z 选项)。 请看下面的截图,
我正在将mysqldump的结果用管道传输到gzip,gzip的速度似乎大大落后 gzip: 34.9MiB 0:01:54 [ 218kiB/s] mysqldump: 735MiB 0:01:5
我是一名优秀的程序员,十分优秀!