2.软文推荐
3.软文推荐
目录: 1、c# .net gzip压缩源码 2、如何用PHP实现页面的GZIP压缩输出 3、2020-11-18 gzip 前后端数据传输压缩‘pako’ 4、如何开启gzip压缩方法大全 5、wordpress优化怎么开启GZIP压缩 6、C# 中GZIP 压缩,求在JAVA中解压代码 c# .net gzip压缩源码你可以使用.net的GZipStream来实现。受以下版本支持:4.5、4、3.5、3.0、2.0
参考:
下面的示例演示如何使用 GZipStream 类压缩和解压缩文件目录。
using System;
using System.IO;
using System.IO.Compression;
namespace zip
{
public class Program
{
public static void Main()
{
string directoryPath = @"c:userspublic eports";
DirectoryInfo directorySelected = new DirectoryInfo(directoryPath);
foreach (FileInfo fileToCompress in directorySelected.GetFiles())
{
Compress(fileToCompress);
}
foreach (FileInfo fileToDecompress in directorySelected.GetFiles("*.gz"))
{
Decompress(fileToDecompress);
}
}
public static void Compress(FileInfo fileToCompress)
{
using (FileStream originalFileStream = fileToCompress.OpenRead())
{
if ((File.GetAttributes(fileToCompress.FullName) FileAttributes.Hidden) != FileAttributes.Hidden fileToCompress.Extension != ".gz")
{
using (FileStream compressedFileStream = File.Create(fileToCompress.FullName + ".gz"))
{
using (GZipStream compressionStream = new GZipStream(compressedFileStream, CompressionMode.Compress))
{
originalFileStream.CopyTo(compressionStream);
Console.WriteLine("Compressed {0} from {1} to {2} bytes.",
fileToCompress.Name, fileToCompress.Length.ToString(), compressedFileStream.Length.ToString());
}
}
}
}
}
public static void Decompress(FileInfo fileToDecompress)
{
using (FileStream originalFileStream = fileToDecompress.OpenRead())
{
string currentFileName = fileToDecompress.FullName;
string newFileName = currentFileName.Remove(currentFileName.Length - fileToDecompress.Extension.Length);
using (FileStream decompressedFileStream = File.Create(newFileName))
{
using (GZipStream decompressionStream = new GZipStream(originalFileStream, CompressionMode.Decompress))
{
decompressionStream.CopyTo(decompressedFileStream);
Console.WriteLine("Decompressed: {0}", fileToDecompress.Name);
}
}
}
}
}
}
如何用PHP实现页面的GZIP压缩输出第一步,你需要对php的设置如下:
php.ini: output_buffering = Off output_handler = ob_gzhandler zlib.output_compression = Off zlib.output_compression_level = -1
第二步,你需要在apache下增加如下设置:
AddOutputFilter DEFLATE html php js css
这样就可以对html php js css进行gzip压缩了。
第三步,你需要使用如下php压缩html并输出到客户端的函数:
function compress_html($string) { return ltrim(rtrim(preg_replace(array("/ *([^ ]*) */","//","'/*[^*]**/'","/ /","/ /","/ /",'/[ ]+/'), array("\1",'','','','','',''),$string))); }
上面的这个正则表达式,很强大的哦,经过我本人亲自测试可使用。
通过以上方法,你就可以将你的html代码压缩然后输出给客户端了。不信你可以查看源代码,就是一行,网页瞬间压缩很小。
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”,这样,在前端接收数据后,就能将数据正常解码并显示。
如何开启gzip压缩方法大全IIS6.0启用Gzip压缩的方法:
1、新建Web服务扩展(如下图)
dll路径:“c:windowssystem32inetsrvgzip.dll”,然后启用。
2、网站服务中开启HTTP压缩支持(如下图)
临时目录需要给IIS用户读写权限。
3、修改IIS配置文件MetaBase.xml
文件路径:“c:windowssystem32inetsrv”(请先备份至他处),打开后搜索“HcDynamicCompressionLevel”,并修改(确定已备份)“Compression/deflate”和“Compression/gzip”两个片段的内容。下面的图n和图b所修改的内容用意是将js、css和php加入到压缩的范畴,数字9代表压缩等级。
(图n)
(图b)
4、重启IIS服务使之生效
——————————————————分分割割—————————————————
Apache启用Gzip压缩的方法:
1、开启模块并添加配置项目
a、vi /etc/httpd/conf/httpd.conf
b、查找LoadModule (/LoadModule),加入“LoadModule deflate_module modules/mod_deflate.so”这行
c、添加配置项目(下段内容)
复制代码代码如下:
IfModule mod_deflate.c
# 压缩等级 9
DeflateCompressionLevel 9
# 压缩类型 html、xml、php、css、js
SetOutputFilter DEFLATE
AddOutputFilterByType DEFLATE text/html text/plain text/xml application/x-javascript application/x-httpd-php
AddOutputFilter DEFLATE js css
/IfModule
2、重启apache使之生效
service httpd start
——————————————————分分割割—————————————————
检测是否支持Gzip
END
注意事项
1. 在编辑MetaBase.xml前需要停止IIS,可以使用 net stop iisadmin
2. 修改完成后开启iisadmin服务,并执行iisreset命令
关于SEO的测试
压缩是否对SEO有影响,经测试,开启后仍然可以被很好的收录。
wordpress优化怎么开启GZIP压缩方法一、通过修改index.php文件开启Gzip压缩
1
下载Wordpress网站根目录index.php文件到本地,用专业网页或代码编辑软件打开编辑,请勿使用系统自带的记事本。填的时候注意标点符号,需英文状态输入。
2
在打开的index.php 中找到:
define(’WP_USE_THEMES’, true);
在后面加上:
ob_start(‘ob_gzhandler’)
3
这种方法最简单,推荐使用。不过有个弊端,就是当wordpress系统升级后需要重新设置。
END
方法二、通过.htaccess启用Gzip压缩
1
如果你的网站空间或服务器支持.htaccess文件,那么在wordpress根目录的.htaccess中添加以下代码,然后上传到wordpress根目录即可。
2
用FTP软件登陆Wordpress博客网站目录。
3
右键.htaccess文件-编辑,打开.htaccess文件。在最后面加上第3点中介绍的两种代码中的任意一种。
步骤阅读
4
实现gzip压缩代码有两种具体如下:
5
第一种:php_value output_handler ob_gzhandler
6
第二种:
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
END
方法三、通过php.ini 启用Gzip压缩
1
如果服务器支持php.ini重定义的话,可以在php.ini中增加以下代码来开启gzip。
zlib.output_compression_level = number
2
其中number为1—9的值,1的压缩比率最低, 建议取5。
END
方法四、安装gzippy插件开启Gzip压缩
1
下载Gzippy插件(下载地址见参考资料。),点wordpress后台的安装插件-上传-选择文件-现在安装,安装完成后启动插件即可。
END
方法五、利用WP Super Cache缓存插件自带功能开启Gzip压缩
1
已安装WP Super Cache缓存插件的朋友,可以在WP Super Cache设置-高级选项中勾选Compress pages so they’re served more quickly to visitors.(Recommended)一项,这样也可以开启Gzip压缩。不过勾选这个选项可能导致网页乱码。
END
方法六、Cpanel控制面板的空间开启Gzip压缩
1
使用Cpanel面板的空间如果服务器支持,可以在Cpanel后台设置开启网站Gzip压缩。在Cpanel面板的软件栏目-优化网站中进行设置。点优化网站后,选择压缩所有内,然后更新设置。
2
3
END
查看Gzip是否开启成功
1
选择以上任一适合自己的方法设置好之后,大家可以到Gzip压缩检测网页(见参考资料)进行测试,看看wordpress Gzip压缩有没有成功。祝你成功。以下是本人博客的Gzip检测图-Gzip压缩已开启:
2
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;

立即
返回
1
目录:1、linux测试网速的工具2、2019-04-13【树莓派笔记】测试网络速度3、如何用Linux命令行测试网速linux测试网速的工具 1、fast 是Netflix提供...