SharpZipLib压缩解压的使用
项目中使用 Velocity 将模板和生成的动态内容(HTML、XML等)合并保存到redis数据库中,考虑到压缩的文件容量会比较小,方便传输而且存储所使用的空间也会比较小,所以要压缩一下,读取的时候也要解压,所以就用到了SharpZipLib。SharpZipLib是一个完全用c#为. net平台编写的Zip、GZip、Tar和BZip2库。官网代码下载https://github.com/icsharpcode/SharpZipLib。如果要使用SharpZipLib,我们可以直接下载源码引入项目,也可以下载SharpZLib.dll。SharpZLib.dll可以从网上下载也可以通过代码自己生成dill。
压缩分为无损压缩和有损压缩,有损压缩指的是压缩之后就无法完整还原原始信息,但是压缩率可以很高,主要应用于视频、话音等数据的压缩,如果没必要完整还原信息,可以使用有损压缩,仅仅损失了一点信息,很难察觉;无损压缩则用于文件等等必须完整还原信息的场合,常见的无损压缩包括Zip、GZip、RAR、Tar、BZip2等。
一、如何使用SharpZipLib
1、项目中引用SharpZLib.dll。
2、本项目中,单独写了一个ZipHelper类,用来使用SharpZipLib中封装的压缩方式。zipHelper类时可以作为使用Zip、Tar、GZip、Lzw、BZip2压缩方式的入口。直接上ZipHelper类的代码吧
using SharpZipLib.BZip2;
using SharpZipLib.Checksum;
using SharpZipLib.Core.Exceptions;
using SharpZipLib.GZip;
using SharpZipLib.Tar;
using SharpZipLib.Zip;
using SharpZipLib.Zip.Compression;
using System;
using System.Collections.Generic;
using System.IO;
using System.Text;
namespace SharpZipLibExample
{
/// <summary>
/// 网上关于压缩的只是很多
/// https://www.cnblogs.com/kissdodog/p/3525295.html
/// </summary>
public class ZipHelper
{
;
#region Zip
/// <summary>
/// Zip文件压缩
/// ZipOutputStream:相当于一个压缩包;
/// ZipEntry:相当于压缩包里的一个文件;
/// 以上两个类是SharpZipLib的主类。
/// </summary>
/// <param name="sourceFileLists"></param>
/// <param name="descFile">压缩文件保存的目录</param>
/// <param name="compression">压缩级别</param>
public static void ZipCompress(List<string> sourceFileLists, string descFile, int compression)
{
|| compression > )
{
throw new ArgumentException("错误的压缩级别");
}
if (!Directory.Exists(new FileInfo(descFile).Directory.ToString()))
{
throw new ArgumentException("保存目录不存在");
}
foreach (string c in sourceFileLists)
{
if (!File.Exists(c))
{
throw new ArgumentException(string.Format("文件{0} 不存在!", c));
}
}
Crc32 crc32 = new Crc32();
using (ZipOutputStream stream = new ZipOutputStream(File.Create(descFile)))
{
stream.SetLevel(compression);
ZipEntry entry;
; i < sourceFileLists.Count; i++)
{
entry = new ZipEntry(Path.GetFileName(sourceFileLists[i]));
entry.DateTime = DateTime.Now;
using (FileStream fs = File.OpenRead(sourceFileLists[i]))
{
byte[] buffer = new byte[fs.Length];
fs.Read(buffer, , buffer.Length);
entry.Size = fs.Length;
crc32.Reset();
crc32.Update(buffer);
entry.Crc = crc32.Value;
stream.PutNextEntry(entry);
stream.Write(buffer, , buffer.Length);
}
stream.CloseEntry();
}
}
}
/// <summary>
/// unZip文件解压缩
/// </summary>
/// <param name="sourceFile">要解压的文件</param>
/// <param name="path">要解压到的目录</param>
public static void ZipDeCompress(string sourceFile, string path)
{
if (!File.Exists(sourceFile))
{
throw new ArgumentException("要解压的文件不存在。");
}
if (!Directory.Exists(path))
{
throw new ArgumentException("要解压到的目录不存在!");
}
using (ZipInputStream s = new ZipInputStream(File.OpenRead(sourceFile)))
{
ZipEntry theEntry;
while ((theEntry = s.GetNextEntry()) != null)
{
string fileName = System.IO.Path.GetFileName(theEntry.Name);
if (fileName != string.Empty)
{
using (FileStream streamWriter = File.Create(path + @"\" + theEntry.Name))
{
;
];
while (true)
{
size = s.Read(data, , data.Length);
)
{
streamWriter.Write(data, , size);
}
else
{
break;
}
}
}
}
}
}
}
/// <summary>
/// 字符串压缩
/// </summary>
/// <param name="text">待压缩的字符串</param>
/// <returns>已压缩的字符串</returns>
public static string ZipCompress(string text)
{
string result = string.Empty;
byte[] data = Encoding.UTF8.GetBytes(text);
byte[] dData = ZipCompress(data);
result = Convert.ToBase64String(dData);
Array.Clear(dData, , dData.Length);
return result;
}
/// <summary>
/// 字符串解压
/// </summary>
/// <param name="text">待解压的字符串</param>
/// <returns>已解压的字符串</returns>
public static string ZipDeCompress(string text)
{
string result = string.Empty;
byte[] data = Convert.FromBase64String(text);
byte[] dData = ZipDeCompress(data);
result = Encoding.UTF8.GetString(dData);
Array.Clear(dData,,dData.Length);
return result;
}
/// <summary>
/// 字节数组压缩
/// </summary>
/// <param name="data">待压缩的字节数组</param>
/// <param name="isClearData">压缩完成后,是否清除待压缩字节数组里面的内容</param>
/// <returns>已压缩的字节数组</returns>
public static byte[] ZipCompress(byte[] data, bool isClearData = true)
{
byte[] bytes = null;
Deflater f = new Deflater(Deflater.BEST_COMPRESSION);
f.SetInput(data);
f.Finish();
;
using (MemoryStream o=new MemoryStream(data.Length))
{
byte[] buffer = new byte[BUFFER_LENGTH];
while (!f.IsFinished)
{
count = f.Deflate(buffer);
o.Write(buffer,,count);
}
bytes = o.ToArray();
}
if (isClearData)
{
Array.Clear(data,,data.Length);
}
return bytes;
}
/// <summary>
/// 字节数组解压缩
/// </summary>
/// <param name="data">待解压缩的字节数组</param>
/// <param name="isClearData">解压缩完成后,是否清除待解压缩字节数组里面的内容</param>
/// <returns>已解压的字节数组</returns>
public static byte[] ZipDeCompress(byte[] data, bool isClearData = true)
{
byte[] bytes = null;
Inflater f = new Inflater();
f.SetInput(data);
;
using (MemoryStream o=new MemoryStream(data.Length))
{
byte[] buffer = new byte[BUFFER_LENGTH];
while (!f.IsFinished)
{
count = f.Inflate(buffer);
o.Write(buffer,,count);
}
bytes = o.ToArray();
}
if (isClearData)
{
Array.Clear(data,,count);
}
return bytes;
}
#endregion
#region GZip
/// <summary>
/// 压缩字符串
/// </summary>
/// <param name="text">待压缩的字符串组</param>
/// <returns>已压缩的字符串</returns>
public static string GZipCompress(string text)
{
string result = string.Empty;
byte[] data = Encoding.UTF8.GetBytes(text);
byte[] cData = GZipCompress(data);
result = Convert.ToBase64String(cData);
Array.Clear(cData, , cData.Length);
return result;
}
/// <summary>
/// 解压缩字符串
/// </summary>
/// <param name="text">待解压缩的字符串</param>
/// <returns>已解压缩的字符串</returns>
public static string GZipDeCompress(string text)
{
string result = string.Empty;
byte[] data = Convert.FromBase64String(text);
byte[] cData = GZipDeCompress(data);
result = Encoding.UTF8.GetString(cData);
Array.Clear(cData, , cData.Length);
return result;
}
/// <summary>
/// 压缩字节数组
/// </summary>
/// <param name="data">待压缩的字节数组</param>
/// <param name="isClearData">压缩完成后,是否清除待压缩字节数组里面的内容</param>
/// <returns>已压缩的字节数组</returns>
public static byte[] GZipCompress(byte[] data, bool isClearData = true)
{
byte[] bytes = null;
try
{
using (MemoryStream o = new MemoryStream())
{
using (Stream s = new GZipOutputStream(o))
{
s.Write(data, , data.Length);
s.Flush();
}
bytes = o.ToArray();
}
}
catch (SharpZipBaseException)
{
}
catch (IndexOutOfRangeException)
{
}
if (isClearData)
Array.Clear(data, , data.Length);
return bytes;
}
/// <summary>
/// 解压缩字节数组
/// </summary>
/// <param name="data">待解压缩的字节数组</param>
/// <param name="isClearData">解压缩完成后,是否清除待解压缩字节数组里面的内容</param>
/// <returns>已解压的字节数组</returns>
public static byte[] GZipDeCompress(byte[] data, bool isClearData = true)
{
byte[] bytes = null;
try
{
using (MemoryStream o = new MemoryStream())
{
using (MemoryStream ms = new MemoryStream(data))
{
using (Stream s = new GZipInputStream(ms))
{
s.Flush();
;
byte[] buffer = new byte[BUFFER_LENGTH];
, buffer.Length)) > )
{
o.Write(buffer, , size);
}
}
}
bytes = o.ToArray();
}
}
catch (SharpZipBaseException)
{
}
catch (IndexOutOfRangeException)
{
}
if (isClearData)
Array.Clear(data, , data.Length);
return bytes;
}
#endregion
#region Tar
/// <summary>
/// 压缩字符串
/// </summary>
/// <param name="text">待压缩的字符串组</param>
/// <returns>已压缩的字符串</returns>
public static string TarCompress(string text)
{
string result = null;
byte[] data = Encoding.UTF8.GetBytes(text);
byte[] dData = TarCompress(data);
result = Convert.ToBase64String(dData);
Array.Clear(dData, , dData.Length);
return result;
}
/// <summary>
/// 解压缩字符串
/// </summary>
/// <param name="text">待解压缩的字符串</param>
/// <returns>已解压的字符串</returns>
public static string TarDeCompress(string text)
{
string result = null;
byte[] data = Convert.FromBase64String(text);
byte[] dData = TarDeCompress(data);
result = Encoding.UTF8.GetString(dData);
Array.Clear(dData, , dData.Length);
return result;
}
/// <summary>
/// 压缩字节数组
/// </summary>
/// <param name="data">待压缩的字节数组</param>
/// <param name="isClearData">压缩完成后,是否清除待压缩字节数组里面的内容</param>
/// <returns>已压缩的字节数组</returns>
public static byte[] TarCompress(byte[] data, bool isClearData = true)
{
byte[] bytes = null;
using (MemoryStream o = new MemoryStream())
{
using (Stream s = new TarOutputStream(o))
{
s.Write(data, , data.Length);
s.Flush();
}
bytes = o.ToArray();
}
if (isClearData)
Array.Clear(data, , data.Length);
return bytes;
}
/// <summary>
/// 解压缩字节数组
/// </summary>
/// <param name="data">待解压缩的字节数组</param>
/// <param name="isClearData">解压缩完成后,是否清除待解压缩字节数组里面的内容</param>
/// <returns>已解压的字节数组</returns>
public static byte[] TarDeCompress(byte[] data, bool isClearData = true)
{
byte[] bytes = null;
using (MemoryStream o = new MemoryStream())
{
using (MemoryStream ms = new MemoryStream(data))
{
using (Stream s = new TarInputStream(ms))
{
s.Flush();
;
byte[] buffer = new byte[BUFFER_LENGTH];
, buffer.Length)) > )
{
o.Write(buffer, , size);
}
}
}
bytes = o.ToArray();
}
if (isClearData)
Array.Clear(data, , data.Length);
return bytes;
}
#endregion
#region BZip
/// <summary>
/// 压缩字符串
/// </summary>
/// <param name="text">待压缩的字符串组</param>
/// <returns>已压缩的字符串</returns>
public static string BZipCompress(string text)
{
string result = null;
byte[] data = Encoding.UTF8.GetBytes(text);
byte[] dData = BZipCompress(data);
result = Convert.ToBase64String(dData);
Array.Clear(dData, , dData.Length);
return result;
}
/// <summary>
/// 解压缩字符串
/// </summary>
/// <param name="text">待解压缩的字符串</param>
/// <returns>已解压的字符串</returns>
public static string BZipDeCompress(string text)
{
string result = null;
byte[] data = Convert.FromBase64String(text);
byte[] dData = BZipDeCompress(data);
result = Encoding.UTF8.GetString(dData);
Array.Clear(dData, , dData.Length);
return result;
}
/// <summary>
/// 压缩字节数组
/// </summary>
/// <param name="data">待压缩的字节数组</param>
/// <param name="isClearData">压缩完成后,是否清除待压缩字节数组里面的内容</param>
/// <returns>已压缩的字节数组</returns>
public static byte[] BZipCompress(byte[] data, bool isClearData = true)
{
byte[] bytes = null;
using (MemoryStream o = new MemoryStream())
{
using (Stream s = new BZip2OutputStream(o))
{
s.Write(data, , data.Length);
s.Flush();
}
bytes = o.ToArray();
}
if (isClearData)
Array.Clear(data, , data.Length);
return bytes;
}
/// <summary>
/// 解压缩字节数组
/// </summary>
/// <param name="data">待解压缩的字节数组</param>
/// <param name="isClearData">解压缩完成后,是否清除待解压缩字节数组里面的内容</param>
/// <returns>已解压的字节数组</returns>
public static byte[] BZipDeCompress(byte[] data, bool isClearData = true)
{
byte[] bytes = null;
using (MemoryStream o = new MemoryStream())
{
using (MemoryStream ms = new MemoryStream(data))
{
using (Stream s = new BZip2InputStream(ms))
{
s.Flush();
;
byte[] buffer = new byte[BUFFER_LENGTH];
, buffer.Length)) > )
{
o.Write(buffer, , size);
}
}
}
bytes = o.ToArray();
}
if (isClearData)
Array.Clear(data, , data.Length);
return bytes;
}
#endregion
}
}
3、程序入口main
using System;
using System.Linq;
using System.Text;
namespace SharpZipLibExample
{
class Program
{
static void Main(string[] args)
{
string strContent = "夜,结束了一天的喧嚣后安静下来,伴随着远处路灯那微弱的光。风,毫无预兆地席卷整片旷野,撩动人的思绪万千。星,遥遥地挂在天空之中,闪烁着它那微微星光,不如阳光般灿烂却如花儿般如痴如醉。";
Console.WriteLine("原文:{0}",strContent);
#region 压缩
string compressContent = ZipHelper.BZipCompress(strContent);
Console.WriteLine("压缩后的内容:{0};压缩后的内容大小:{1}", compressContent, Convert.FromBase64String(compressContent).Count().ToString());
#endregion
#region 解压缩
strContent = ZipHelper.BZipDeCompress(compressContent);
Console.WriteLine("解压缩后的内容:{0};解压缩后的内容大小:{1}", strContent,Encoding.UTF8.GetBytes(strContent).Count().ToString());
#endregion
Console.ReadKey();
}
}
}
完整的Demo下载地址https://download.csdn.net/download/u011392711/10827889
SharpZipLib压缩解压的使用的更多相关文章
- .NET使用ICSharpCode.SharpZipLib压缩/解压文件
SharpZipLib是国外开源加压解压库,可以方便的对文件进行加压/解压 1.下载ICSharpCode.SharpZipLib.dll,并复制到bin目录下 http://www.icsharpc ...
- SharpZipLib压缩解压
一.介绍 SharpZipLib是一个完全由C#编写的ZIP,GZIP,Tar和BZIP2 Library,可以方便的支持这几种格式的压缩和解压缩. https://github.com/icshar ...
- ICSharpCode.SharpZipLib压缩解压
一.使用ICSharpCode.SharpZipLib.dll: 下载地址 http://www.icsharpcode.net/OpenSource/SharpZipLib/Download.asp ...
- C#基础知识之SharpZipLib压缩解压的使用
项目中使用 Velocity 将模板和生成的动态内容(HTML.XML等)合并保存到redis数据库中,考虑到压缩的文件容量会比较小,方便传输而且存储所使用的空间也会比较小,所以要压缩一下,读取的时候 ...
- C#使用SharpZipLib压缩解压文件
#region 加压解压方法 /// <summary> /// 功能:压缩文件(暂时只压缩文件夹下一级目录中的文件,文件夹及其子级被忽略) /// </summary> // ...
- 通过SharpZipLib来压缩解压文件
在项目开发中,一些比较常用的功能就是压缩解压文件了,其实类似的方法有许多 ,现将通过第三方类库SharpZipLib来压缩解压文件的方法介绍如下,主要目的是方便以后自己阅读,当然可以帮到有需要的朋友更 ...
- 使用SharpZIpLib写的压缩解压操作类
使用SharpZIpLib写的压缩解压操作类,已测试. public class ZipHelper { /// <summary> /// 压缩文件 /// </summary&g ...
- (转载)C#压缩解压zip 文件
转载之: C#压缩解压zip 文件 - 大气象 - 博客园http://www.cnblogs.com/greatverve/archive/2011/12/27/csharp-zip.html C# ...
- 使用C#压缩解压rar和zip格式文件
为了便于文件在网络中的传输和保存,通常将文件进行压缩操作,常用的压缩格式有rar.zip和7z,本文将介绍在C#中如何对这几种类型的文件进行压缩和解压,并提供一些在C#中解压缩文件的开源库. 在C#. ...
随机推荐
- gulp+tp5配置
优化了文件过滤,更改文件只会重新生成修改的文件 项目目录构建: 在入口文件public下,创建html目录,作为前台静态资源目录 gulp.js文件 /*! * gulp * $ npm instal ...
- 如何检测或判断一个文件或字节流(无BOM)是什么编码类型
前言: 昨天,在文章:终于等到你:CYQ.Data V5系列 (ORM数据层,支持.NET Core)最新版本开源了 中, 不小心看到一条留言: 然后就去该地址看了一下,这一看,顺带折腾了一天. 今天 ...
- js 一些工具函数
1.js金钱转换类 这是一个远古时期的函数,拿来分享一下,它将输入的数字保留2位小数并补0 function formatAsMoney(mnt) { mnt -= 0; mnt = (Math.ro ...
- BTrace 问题辅助排查工具使用手册
BTrace是调试神器,可以通过自己编写的脚本,获取应用的一切调用信息.而不需要重启应用! Btrace 项目源码信息(你行你上~) 项目地址:http://github.com/btraceio/b ...
- SpringBoot 2.X集成Hive-jdbc 3.1.1
最近公司有一个需求,需求的内容是根据用户页面选择的参数条件查询Hive,数量量大致是300万以内,要求3秒响应.使用的其它的技术就不要说了,先说说SpingBoot集成Hive-jdbc吧,网上虽然有 ...
- sklearn中的Pipeline
在将sklearn中的模型持久化时,使用sklearn.pipeline.Pipeline(steps, memory=None)将各个步骤串联起来可以很方便地保存模型. 例如,首先对数据进行了PCA ...
- java~modelMapper需要注意的几点
对于modelMapper来说,主要实现的是对象与对象的赋值,在这微服务里的数据传输对象中用的比较多,DTO这个对象是从业务模型抽象出来的,满足某一种业务,它与数据持久化模型没有关系,而如果我们把数据 ...
- BugkuCTF~代码审计~WriteUp
第一题:extract变量覆盖 知识简介 extract()函数语法: extract(array,extract_rules,prefix) 参数 描述 array必需. 规定要使用的数组. ext ...
- 使用Atlas进行元数据管理之容错和高可用
1. 介绍 Apache Atlas使用各种系统并与之交互,为数据管理员提供元数据管理和数据血缘信息.通过适当地选择和配置这些依赖关系,可以使用Atlas实现高度的服务可用性.本文档介绍了Atlas中 ...
- go并发调度原理学习
aaarticlea/jpeg;base64,/9j/4AAQSkZJRgABAQAAkACQAAD/4QB0RXhpZgAATU0AKgAAAAgABAEaAAUAAAABAAAAPgEbAAUAA