详解详解C#压缩、解压文件夹压缩、解压文件夹/文件文件(带密码带密码)
前言前言
今天梳理一下项目中用到的压缩、解压文件夹或文件的方法,发现因为需求不同,已经用了好几个不同组件。今天就好好整理
记录下,别下次遇到需求又重头开始了。
DotNetZip
DotNetZip是一个开源的免费类库,主要提供了快速操作zip文件的工具集,VB、C#任何.Net语言都可以通过它创建、解压缩
zip文件。我使用该类库最主要的目的还是因为它可以创建带密码保护的压缩文件。
只有设置了zip.Password = “password”之后,被压缩的文件才会有密码保护
/// <summary>
/// 压缩文件/文件夹
/// </summary>
/// <param name="filePath">需要压缩的文件/文件夹路径</param>
/// <param name="zipPath">压缩文件路径(zip后缀)</param>
/// <param name="password">密码</param>
/// <param name="filterExtenList">需要过滤的文件后缀名</param>
public static void CompressionFile(string filePath, string zipPath, string password = "", List<string> filterExtenList = null)
{
try
{
using (ZipFile zip = new ZipFile(Encoding.UTF8))
{
if (!string.IsNullOrWhiteSpace(password))
{
zip.Password = password;
}
if (Directory.Exists(filePath))
{
if (filterExtenList == null)
zip.AddDirectory(filePath);
else
AddDirectory(zip, filePath, filePath, filterExtenList);
}
else if (File.Exists(filePath))
{
zip.AddFile(filePath,"");
}
zip.Save(zipPath);
}
}
catch (Exception ex)
{
throw ex;
}
}
/// <summary>
/// 添加文件夹
/// </summary>
/// <param name="zip">ZipFile对象</param>
/// <param name="dirPath">需要压缩的文件夹路径</param>
/// <param name="rootPath">根目录路径</param>
/// <param name="filterExtenList">需要过滤的文件后缀名</param>
public static void AddDirectory(ZipFile zip, string dirPath, string rootPath, List<string> filterExtenList)
{
var files = Directory.GetFiles(dirPath);
for (int i = 0; i < files.Length; i++)
{
//如果Contains不支持第二个参数,就用.ToLower()
if (filterExtenList == null || (filterExtenList != null && !filterExtenList.Any(d => Path.GetExtension(files[i]).Contains(d,
StringComparison.OrdinalIgnoreCase))))
{
//获取相对路径作为zip文件中目录路径
zip.AddFile(files[i], Path.GetRelativePath(rootPath, dirPath));
//如果没有Path.GetRelativePath方法,可以用下面代码替换
//string relativePath = Path.GetFullPath(dirPath).Replace(Path.GetFullPath(rootPath), "");
//zip.AddFile(files[i], relativePath);
评论0