当前位置:首页 > 代码 > 正文

gzip压缩代码(gzip 压缩算法)

admin 发布:2022-12-19 16:57 163


本篇文章给大家谈谈gzip压缩代码,以及gzip 压缩算法对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。

本文目录一览:

C# 中GZIP 压缩,求在JAVA中解压代码

byte[] buf = new byte[4096*2];

//建立字节数组输入流

ByteArrayInputStream i = new ByteArrayInputStream(buffer);

//建立gzip解压输入流

GZIPInputStream gzin = new GZIPInputStream(i);

int size = gzin.read(buf);

i.close();

gzin.close();

byte b[] = new byte[size];

System.arraycopy(buf,0,b,0,size);

return b;

2020-11-18 gzip 前后端数据传输压缩‘pako’

 let zlib = require("pako"); //引入

//压缩方法 用来将大数据压缩后在传给后端

Vue.prototype.zip = function (str) {

            //encodeURIComponent 将字符串作为URI组件进行编码

            //zlib.gzip() 将编码后的数据进行压缩,string类型

            let binaryString = zlib.gzip(encodeURIComponent(str), {

                to: "string"

            });

            //btoa()将压缩后的数据变成base64格式

            return btoa(binaryString);

        },

//解压缩方法,前端接受后端大数据后,先解压缩在进行后面的逻辑

        Vue.prototype.unzip = function (b64Data) {

            //atob()将base64格式数据转化成压缩数据

            let strData = atob(b64Data);

            //split()方法用于把一个字符串分割成字符串数组

            //通过map函数进行遍历,并对每一个进行 Unicode 编码

            let charData = strData.split("").map(function (x) {

                //charCodeAt() 方法可返回指定位置的字符的 Unicode 编码

                return x.charCodeAt(0);

            });

            //Uint8Array 8 位无符号整数值的类型化数组

            let binData = new Uint8Array(charData);

            // console.log(binData);

            //解压缩 充气

            let data = zlib.inflate(binData);

            //fromCharCode 将 Unicode 编码转为一个字符:

            // console.log(data);

           //分片解压缩,防止数据量过大,浏览器栈溢出报错

            let chunk = 8 * 1024;

            let res = "";

            let dataLength = data.length / chunk;

            let i;

            for (i = 0; i  dataLength; i++) {

                res += String.fromCharCode.apply(

                    null,

                    data.slice(i * chunk, (i + 1) * chunk)

                );

            }

            res += String.fromCharCode.apply(null, data.slice(i * chunk));

            //decodeURIComponent() 对 encodeURIComponent() 函数编码的 URI 进行解码

            strData = res;

            return decodeURIComponent(strData);

        },

2021-02-20:

    问题更新:最新客户在使用的过程中,发现页面展示会出现莫名其妙的“+”。

    对此,我们进行了一番查询,发现问题原因如下:后端在将数据压缩的过程中,正常情况下会将数据中的“+”号编码成%2B,同时会将“ 空格 ”编码成“%20”,那么前端接收以后,就可以进行解码。

    但是,我们发现数据中的“+”会被正常编码,但是空格却不会,而是编码成了“+”.那么,前端接收以后在解码的过程中,就无法对“+”进行解码,就会造成显示和真实数据不一致。

解决方案:后端在压缩完成后,再将所有的“+”编码替换成“%20”,这样,在前端接收数据后,就能将数据正常解码并显示。

wordpress优化怎么开启GZIP压缩

方法一、通过修改index.php文件开启Gzip压缩

下载Wordpress网站根目录index.php文件到本地,用专业网页或代码编辑软件打开编辑,请勿使用系统自带的记事本。填的时候注意标点符号,需英文状态输入。

在打开的index.php

中找到:

define(’WP_USE_THEMES’,

true);

在后面加上:

ob_start(‘ob_gzhandler’)

这种方法最简单,推荐使用。不过有个弊端,就是当wordpress系统升级后需要重新设置。

方法二、通过.htaccess启用Gzip压缩

如果你的网站空间或服务器支持.htaccess文件,那么在wordpress根目录的.htaccess中添加以下代码,然后上传到wordpress根目录即可。

用FTP软件登陆Wordpress博客网站目录。

右键.htaccess文件-编辑,打开.htaccess文件。在最后面加上第3点中介绍的两种代码中的任意一种。

实现gzip压缩代码有两种具体如下:

第一种:php_value

output_handler

ob_gzhandler

第二种:

IfModule

mod_expires.c

ExpiresActive

On

ExpiresByType

image/gif

A2592000

ExpiresByType

image/jpeg

A2592000

ExpiresByType

image/png

A2592000

ExpiresByType

image/x-icon

A2592000

ExpiresByType

application/x-javascript

A604800

ExpiresByType

text/css

A604800

/IfModule

IfModule

mod_deflate.c

SetOutputFilter

DEFLATE

AddOutputFilterByType

DEFLATE

text/html

text/css

image/gif

image/jpeg

image/png

application/x-javascript

/IfModule

方法三、通过php.ini

启用Gzip压缩

如果服务器支持php.ini重定义的话,可以在php.ini中增加以下代码来开启gzip。

zlib.output_compression_level

=

number

其中number为1—9的值,1的压缩比率最低,

建议取5。

方法四、安装gzippy插件开启Gzip压缩

下载Gzippy插件(下载地址见参考资料。),点wordpress后台的安装插件-上传-选择文件-现在安装,安装完成后启动插件即可。

方法五、利用WP

Super

Cache缓存插件自带功能开启Gzip压缩

已安装WP

Super

Cache缓存插件的朋友,可以在WP

Super

Cache设置-高级选项中勾选Compress

pages

so

they’re

served

more

quickly

to

visitors.(Recommended)一项,这样也可以开启Gzip压缩。不过勾选这个选项可能导致网页乱码。

方法六、Cpanel控制面板的空间开启Gzip压缩

使用Cpanel面板的空间如果服务器支持,可以在Cpanel后台设置开启网站Gzip压缩。在Cpanel面板的软件栏目-优化网站中进行设置。点优化网站后,选择压缩所有内,然后更新设置。

查看Gzip是否开启成功

选择以上任一适合自己的方法设置好之后,大家可以到Gzip压缩检测网页(见参考资料)进行测试,看看wordpress

Gzip压缩有没有成功。祝你成功。以下是本人博客的Gzip检测图-Gzip压缩已开启:

注意事项及说明

如果在.htaccess文件中禁止了gzip功能的话,那在php.ini文件中开启后也需在.htaccess文件中开启gzip,否则没有效果。

开启wordpress的gzip功能后,服务器将在页面传输前将页面压缩后传送,可以有效减少服务器的带宽使用,也可以加速页面下载。

另外请注意只能选择一种方式来开启wordpress

gzip压缩,否则有可能造成冲突,请谨记。

关于gzip压缩代码和gzip 压缩算法的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。

版权说明:如非注明,本站文章均为 AH站长 原创,转载请注明出处和附带本文链接;

本文地址:http://ahzz.com.cn/post/14414.html


取消回复欢迎 发表评论:

分享到

温馨提示

下载成功了么?或者链接失效了?

联系我们反馈

立即下载