0

0

C# 如何压缩和解压文件 - ZipArchive类的使用

星降

星降

发布时间:2026-01-07 10:35:02

|

610人浏览过

|

来源于php中文网

原创

ZipArchive 是 .NET 原生轻量 ZIP 处理方案,支持压缩、解压及流式读取;需注意目录创建、路径安全、ZIP64、密码保护、空文件夹模拟及中文编码等细节。

c# 如何压缩和解压文件 - ziparchive类的使用

在 C# 中,ZipArchive 类(位于 System.IO.Compression 命名空间)是处理 ZIP 文件最常用、最轻量的方式,无需第三方库,.NET Framework 4.5+ 和 .NET Core/.NET 5+ 均原生支持。

压缩多个文件到 ZIP

ZipArchive 创建 ZIP 文件,本质是创建一个 FileStream,再用它初始化 ZipArchive(模式为 Create),然后逐个添加文件条目。

  • 目标 ZIP 文件路径需确保目录存在,否则会抛出异常;建议先调用 Directory.CreateDirectory(Path.GetDirectoryName(zipPath))
  • 添加文件时,zip.CreateEntry() 的参数是 ZIP 内部的相对路径(如 "docs/report.txt"),不是磁盘绝对路径
  • 推荐使用 using 确保流和归档正确释放,避免文件被占用
示例:
string zipPath = @"C:\output\archive.zip";
string[] files = { @"C:\data\file1.txt", @"C:\data\image.png" };

using (var archive = ZipFile.Open(zipPath, ZipArchiveMode.Create)) { foreach (string file in files) { string entryName = Path.GetFileName(file); // 或自定义子目录结构 var entry = archive.CreateEntry(entryName); using (var entryStream = entry.Open()) using (var fileStream = File.OpenRead(file)) { fileStream.CopyTo(entryStream); } } }

解压 ZIP 到指定文件夹

解压更简单:用 ZipFile.OpenRead() 打开只读归档,遍历 Entries,对每个条目调用 ExtractToFile(),自动创建中间目录。

  • ExtractToFile() 第二个参数设为 true 可覆盖已存在的同名文件
  • 注意条目路径可能含 "../"(路径遍历风险),生产环境应校验 entry.FullName 是否安全(如不以 "..\" 开头且不含非法字符)
  • 若只需解压部分文件,可按 entry.Nameentry.FullName 过滤
示例:
string zipPath = @"C:\output\archive.zip";
string extractPath = @"C:\extracted";

Directory.CreateDirectory(extractPath);

using (var archive = ZipFile.OpenRead(zipPath)) { foreach (ZipArchiveEntry entry in archive.Entries) { string destinationPath = Path.Combine(extractPath, entry.FullName); // 安全校验(简化版) if (destinationPath.Contains("..\") || destinationPath.Contains("../")) throw new InvalidOperationException("Suspicious path detected");

    Directory.CreateDirectory(Path.GetDirectoryName(destinationPath));
    entry.ExtractToFile(destinationPath, overwrite: true);
}

}

95Shop仿醉品商城
95Shop仿醉品商城

95Shop可以免费下载使用,是一款仿醉品商城网店系统,内置SEO优化,具有模块丰富、管理简洁直观,操作易用等特点,系统功能完整,运行速度较快,采用ASP.NET(C#)技术开发,配合SQL Serve2000数据库存储数据,运行环境为微软ASP.NET 2.0。95Shop官方网站定期开发新功能和维护升级。可以放心使用! 安装运行方法 1、下载软件压缩包; 2、将下载的软件压缩包解压缩,得到we

下载

读取 ZIP 内容而不解压

有时只需要检查 ZIP 里有什么文件或读取某个文本内容,不必落地到磁盘。这时直接打开条目的流即可。

  • entry.Open() 获取可读流,配合 StreamReader 读取文本内容
  • 注意:entry.Length 是原始未压缩大小,entry.CompressedLength 是 ZIP 中实际占用字节
  • 如果 ZIP 很大但只读少量小文件,这种方式内存友好
示例(读取 ZIP 中的 config.json):
using (var archive = ZipFile.OpenRead(zipPath))
{
    var configEntry = archive.GetEntry("config.json");
    if (configEntry != null)
    {
        using (var stream = configEntry.Open())
        using (var reader = new StreamReader(stream))
        {
            string json = reader.ReadToEnd();
            // 解析 JSON...
        }
    }
}

常见注意事项

ZipArchive 灵活但有些细节容易踩坑:

  • 不支持 ZIP64(超 4GB 或超 65535 个文件)——老版本 .NET 不支持,.NET 6+ 已默认开启 ZIP64 支持
  • 密码保护 ZIP 不被原生 ZipArchive 支持,需用 SharpZipLibDotNetZip
  • 添加空文件夹?ZIP 标准本身不存“空目录”,但可通过添加路径以 "/" 结尾的条目模拟(如 archive.CreateEntry("logs/")
  • 中文文件名乱码?确保 ZIP 由 UTF-8 编码生成(.NET Core+ 默认 UTF-8;.NET Framework 需设置 ZipArchiveEntry.ExternalAttributes 或改用 SharpZipLib

基本上就这些。用好 ZipArchive,压缩解压逻辑清晰、性能稳定,适合绝大多数本地文件归档场景。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

406

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

531

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

308

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

74

2025.09.10

length函数用法
length函数用法

length函数用于返回指定字符串的字符数或字节数。可以用于计算字符串的长度,以便在查询和处理字符串数据时进行操作和判断。 需要注意的是length函数计算的是字符串的字符数,而不是字节数。对于多字节字符集,一个字符可能由多个字节组成。因此,length函数在计算字符串长度时会将多字节字符作为一个字符来计算。更多关于length函数的用法,大家可以阅读本专题下面的文章。

912

2023.09.19

length函数用法
length函数用法

length函数用于返回指定字符串的字符数或字节数。可以用于计算字符串的长度,以便在查询和处理字符串数据时进行操作和判断。 需要注意的是length函数计算的是字符串的字符数,而不是字节数。对于多字节字符集,一个字符可能由多个字节组成。因此,length函数在计算字符串长度时会将多字节字符作为一个字符来计算。更多关于length函数的用法,大家可以阅读本专题下面的文章。

912

2023.09.19

C++ 高性能计算与并行编程
C++ 高性能计算与并行编程

本专题专注于 C++ 在高性能计算(HPC)与并行编程中的应用,涵盖多线程、并发数据处理、OpenMP、MPI、GPU加速等技术。通过实际案例,帮助开发者掌握 如何利用 C++ 进行大规模数据计算和并行处理,提高程序的执行效率,适应高性能计算与数据密集型应用场景。

4

2026.01.08

C++ 高性能计算与并行编程
C++ 高性能计算与并行编程

本专题专注于 C++ 在高性能计算(HPC)与并行编程中的应用,涵盖多线程、并发数据处理、OpenMP、MPI、GPU加速等技术。通过实际案例,帮助开发者掌握 如何利用 C++ 进行大规模数据计算和并行处理,提高程序的执行效率,适应高性能计算与数据密集型应用场景。

0

2026.01.08

PPT动态图表制作教程大全
PPT动态图表制作教程大全

本专题整合了PPT动态图表制作相关教程,阅读专题下面的文章了解更多详细内容。

36

2026.01.07

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
C# 教程
C# 教程

共94课时 | 6.2万人学习

C 教程
C 教程

共75课时 | 3.9万人学习

C++教程
C++教程

共115课时 | 11.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号