当前位置: 首页 > article >正文

C#文件压缩与解压缩全攻略:使用ZipFile与ZipArchive实现高效操作

C#文件压缩与解压缩全攻略:使用ZipFileZipArchive实现高效操作

在.NET 开发中,文件压缩与解压缩是常见的需求。无论是减少存储空间、加速网络传输,还是实现数据备份,System.IO.Compression命名空间都提供了强大的工具。本文将结合微软官方文档示例,详细介绍如何使用ZipFileZipArchive类完成压缩和解压缩任务,并涵盖安全处理、高级操作等场景。

一、环境准备:安装依赖包

在开始之前,确保项目已引入必要的库:

  • .NET Core/.NET 5+:默认包含System.IO.Compression,无需额外安装。
  • .NET Framework:需通过 NuGet 安装以下两个包:
Install-Package System.IO.Compression
Install-Package System.IO.Compression.ZipFile

同时,在代码中引用命名空间:

using System.IO.Compression;
using System.IO;

二、基础操作:快速创建与提取ZIP文件

示例 1:压缩文件夹并解压缩

class Program
{static void Main(){var sourceFolder = @".\source";       // 待压缩文件夹(需提前创建)var zipPath = @".\result.zip";       // 生成的ZIP文件路径var extractFolder = @".\extract";    // 解压缩目标文件夹// 压缩整个文件夹ZipFile.CreateFromDirectory(sourceFolder, zipPath);Console.WriteLine("压缩完成!");// 解压缩ZIP文件到指定文件夹ZipFile.ExtractToDirectory(zipPath, extractFolder);Console.WriteLine("解压缩完成!");}}

关键点

  • ZipFile.CreateFromDirectory会递归压缩文件夹内的所有文件和子目录。
  • ExtractToDirectory会自动创建目标文件夹(若不存在)。

三、安全解压缩:防范路径遍历攻击

在解压缩时,恶意 ZIP 文件可能包含跨目录路径(如../../恶意文件.txt),导致文件被写入非预期位置。以下是安全处理示例:

示例 2:仅提取.txt 文件并验证路径安全

class Program
{static void Main(){var zipPath = @".\result.zip";Console.Write("请输入解压缩路径:");var extractPath = Console.ReadLine();// 标准化路径并确保以目录分隔符结尾extractPath = Path.GetFullPath(extractPath).TrimEnd(Path.DirectorySeparatorChar) + Path.DirectorySeparatorChar;using (ZipArchive archive = ZipFile.OpenRead(zipPath)){foreach (ZipArchiveEntry entry in archive.Entries){if (!entry.FullName.EndsWith(".txt", StringComparison.OrdinalIgnoreCase)){continue; // 跳过非.txt文件}// 组合完整目标路径并验证是否在安全范围内var targetPath = Path.GetFullPath(Path.Combine(extractPath, entry.FullName));if (targetPath.StartsWith(extractPath, StringComparison.Ordinal)){entry.ExtractToFile(targetPath); // 安全解压缩Console.WriteLine($"提取文件:{entry.FullName}");}}}}
}

安全策略

  1. 使用Path.GetFullPath去除相对路径隐患。
  2. 检查目标路径是否以解压缩根路径开头,防止跨目录写入。

四、高级操作:更新现有 ZIP 文件

ZipArchive类支持在已有的 ZIP 文件中添加、修改或删除文件,适用于增量更新场景。

示例 3:向现有 ZIP 文件添加新文件

class Program
{static void Main(){string existingZip = @".\release.zip";using (FileStream stream = new FileStream(existingZip, FileMode.Open))using (ZipArchive archive = new ZipArchive(stream, ZipArchiveMode.Update)){// 创建新文件条目并写入内容ZipArchiveEntry readme = archive.CreateEntry("Readme.txt");using (StreamWriter writer = new StreamWriter(readme.Open())){writer.WriteLine("压缩包说明:");writer.WriteLine("包含应用程序文件和配置文档");}}Console.WriteLine("文件添加成功!");}}

注意事项

  • ZipArchiveMode.Update模式下,需确保 ZIP 文件未被其他进程锁定。
  • 若文件已存在,CreateEntry会抛出异常,可先用GetEntry检查是否存在。

五、GZip 压缩:处理单个文件

除了 ZIP 格式,GZipStream类可用于创建.gz 格式的压缩文件,适合单个文件的高效压缩。

示例 4:压缩目录内的所有文件为.gz

public class GZipTool
{private static string sourceDir = @".\temp"; // 源目录(需包含待压缩文件)public static void Main(){var dir = new DirectoryInfo(sourceDir);CompressDirectory(dir); // 压缩所有非.gz文件DecompressAllGzFiles(dir); // 解压缩所有.gz文件}// 压缩单个文件private static void CompressFile(FileInfo file){using (var inStream = file.OpenRead())using (var outStream = File.Create(file.FullName + ".gz"))using (var gzip = new GZipStream(outStream, CompressionMode.Compress)){inStream.CopyTo(gzip); // 直接将源文件内容写入压缩流}Console.WriteLine(\$"已压缩:{file.Name}");}// 解压缩.gz文件private static void DecompressFile(FileInfo file){var destPath = file.FullName.Replace(".gz", "");using (var inStream = file.OpenRead())using (var outStream = File.Create(destPath))using (var gzip = new GZipStream(inStream, CompressionMode.Decompress)){gzip.CopyTo(outStream); // 将压缩流内容写入目标文件}Console.WriteLine(\$"已解压缩:{file.Name}");}
}

适用场景

  • 需要与其他系统(如 Linux)的 gzip 工具兼容。
  • 仅需压缩单个文件,无需目录结构。

六、性能优化与最佳实践

    1. 选择压缩模式
    • CompressionLevel.Optimal(默认):平衡压缩比与速度。
    • CompressionLevel.Fastest:适用于对性能敏感的场景(如实时传输)。
    • CompressionLevel.NoCompression:仅打包不压缩,用于快速归档。
    1. 大文件处理
    • 使用流式操作(如CopyTo)避免一次性加载大量数据到内存。
    • 对超大文件,可考虑分块压缩(需手动管理ZipArchiveEntry的流)。
    1. 异常处理
    • 始终使用using语句释放FileStreamZipArchive资源。
    • 捕获IOException(如文件被占用)和InvalidDataException(如损坏的 ZIP 文件)。

七、总结

本文通过示例,详细介绍了 C# 中文件压缩与解压缩的核心技术:

  • ZipFile:适合快速创建、提取 ZIP 文件,支持文件夹级操作。
  • ZipArchive:提供细粒度控制,可灵活修改 ZIP 内容。
  • GZipStream:用于单个文件的高效压缩,兼容标准.gz 格式。

在实际开发中,建议根据场景选择合适的工具:简单归档优先使用ZipFile,复杂操作(如增量更新)选择ZipArchive,而单文件压缩可考虑 GZip。同时,务必注意解压缩时的路径安全,避免潜在的安全漏洞。

如果需要进一步探索,可查阅微软官方文档:文件压缩与解压缩指南。

相关文章:

C#文件压缩与解压缩全攻略:使用ZipFile与ZipArchive实现高效操作

C#文件压缩与解压缩全攻略:使用ZipFile与ZipArchive实现高效操作 在.NET 开发中,文件压缩与解压缩是常见的需求。无论是减少存储空间、加速网络传输,还是实现数据备份,System.IO.Compression命名空间都提供了强大的工具。本文将结…...

1、Go语言基础中的基础

摘要:马士兵教育的Go语言基础的视频笔记。 第一章:走进Golang 1.1、Go的SDK介绍 1.2、Go的项目基本目录结构 1.3、HelloWorld 1.4、编译 1.5、执行 1.6、一步到位 1.7、执行流程分析 1.8、语法注意事项 (1)源文件以"go&qu…...

Go语言基础知识总结(超详细整理)

1. Go语言简介 Go语言(又称Golang)是Google于2009年发布的开源编程语言,具备简洁、高效、并发等特点,适合服务器开发、云计算、大数据等场景。 2. 环境安装与配置 下载地址:https://golang.org/dl/安装后配置环境变量…...

buuctf——web刷题第二页

[网鼎杯 2018]Fakebook和[SWPU2019]Web1没有,共30题 目录 [BSidesCF 2020]Had a bad day [网鼎杯 2020 朱雀组]phpweb [BJDCTF2020]The mystery of ip [BUUCTF 2018]Online Tool [GXYCTF2019]禁止套娃 [GWCTF 2019]我有一个数据库 [CISCN2019 华北赛区 Day2…...

MVC与MVP设计模式对比详解

MVC(Model-View-Controller)和MVP(Model-View-Presenter)是两种广泛使用的分层架构模式,核心目标是解耦业务逻辑、数据和界面,提升代码可维护性和可测试性。以下是它们的对比详解: MVC 模式&…...

内嵌式mqtt server

添加moquette依赖 <dependency><groupId>io.moquette</groupId><artifactId>moquette-broker</artifactId><version>0.17</version><exclusions><exclusion><groupId>org.slf4j</groupId><artifactId>…...

二叉树的遍历总结

144.二叉树的前序遍历(opens new window)145.二叉树的后序遍历(opens new window)94.二叉树的中序遍历 二叉数的先中后序统一遍历法 public static void preOrder(BiTree root){BiTree p root;LinkedList<BiTree> stack new LinkedList<>();while(p ! null ||…...

win32相关(远程线程和远程线程注入)

远程线程和远程线程注入 CreateRemoteThread函数 作用&#xff1a;创建在另一个进程的虚拟地址空间中运行的线程 HANDLE CreateRemoteThread([in] HANDLE hProcess, // 需要在哪个进程中创建线程[in] LPSECURITY_ATTRIBUTES lpThreadAttributes, // 安全…...

【Go语言基础【5】】Go module概述:项目与依赖管理

文章目录 一、Go Module 概述二、Go Module 核心特性1. 项目结构2. 依赖查找机制 三、如何启用 Go Module四、创建 Go Module 项目五、Go Module 关键命令 一、Go Module 概述 Go Module 是 Go 1.11 版本&#xff08;2018 年 8 月&#xff09;引入的依赖管理系统&#xff0c;用…...

[Spring]-AOP

AOP场景 AOP: Aspect Oriented Programming (面向切面编程) OOP: Object Oriented Programming (面向对象编程) 场景设计 设计: 编写一个计算器接口和实现类&#xff0c;提供加减乘除四则运算 需求: 在加减乘除运算的时候需要记录操作日志(运算前参数、运算后结果)实现方案:…...

agent 开发

什么是 agent&#xff1f; Agent智能体&#xff08;又称AI Agent&#xff09;是一种具备自主感知、决策与行动能力的智能系统&#xff0c;其核心在于模仿人类的认知过程来处理复杂任务。以下是其关键特性和发展现状的综合分析&#xff1a; 一、核心定义与特征 #‌## 自主决策…...

多系统一键打包docker compose下所有镜像并且使用

本方法适合在已经pull好docker镜像正常使用的机器 将环境迁移到无网络 或者网络不好的机器使用 linux 用法 cd 到 docker-compose.yml 所在目录 ./save_compose_images.sh #!/bin/bash # 拉取镜像并保存为 .tar 文件 docker save $(docker-compose images | awk {print…...

Golang——5、函数详解、time包及日期函数

函数详解、time包及日期函数 1、函数1.1、函数定义1.2、函数参数1.3、函数返回值1.4、函数类型与变量1.5、函数作参数和返回值1.6、匿名函数、函数递归和闭包1.7、defer语句1.8、panic和recover 2、time包以及日期函数2.1、time.Now()获取当前时间2.2、Format方法格式化输出日期…...

【HarmonyOS 5】出行导航开发实践介绍以及详细案例

以下是 ‌HarmonyOS 5‌ 出行导航的核心能力详解&#xff08;无代码版&#xff09;&#xff0c;聚焦智能交互、多端协同与场景化创新&#xff1a; 一、交互革新&#xff1a;从被动响应到主动服务 ‌意图驱动导航‌ ‌自然语义理解‌&#xff1a;用户通过语音指令&#xff08;如…...

深度学习环境配置指南:基于Anaconda与PyCharm的全流程操作

一、环境搭建前的准备 1. 查看基础环境位置 conda env list 操作说明&#xff1a;通过该命令确认Anaconda默认环境&#xff08;base&#xff09;所在磁盘路径&#xff08;如D盘&#xff09;&#xff0c;后续操作需跳转至该磁盘根目录。 二、创建与激活独立虚拟环境 1. 创…...

03 Deep learning神经网络的编程基础 代价函数(Cost function)--吴恩达

深度学习中的损失函数(Cost Function)用于量化模型预测与真实数据的差距,是优化神经网络的核心指标。以下是常见类型及数学表达: 核心原理 逻辑回归通过sigmoid函数将线性预测结果转换为概率: y ^ ( i ) \hat{y}^{(i)}...

打卡day46

知识点回顾&#xff1a; 不同CNN层的特征图&#xff1a;不同通道的特征图什么是注意力&#xff1a;注意力家族&#xff0c;类似于动物园&#xff0c;都是不同的模块&#xff0c;好不好试了才知道。通道注意力&#xff1a;模型的定义和插入的位置通道注意力后的特征图和热力图 内…...

在SpringBoot中使用AWS SDK实现邮箱验证码服务

1.依赖导入&#xff08;maven&#xff09; <dependency><groupId>software.amazon.awssdk</groupId><artifactId>ses</artifactId><version>2.31.46</version></dependency> 2.申请两个key 发件人邮箱需要验证&#xff1a; …...

AndroidR车机TextToSpeech音频焦点异常问题分析

一、引言 文章《Android车机之TextToSpeech》介绍了TextToSpeech的使用,当前较多座舱系统语音服务都接入了原生TextToSpeech接口调用。 我司自研语音TTS服务,也接入了此TTS接口调用,对外提供TextToSpeech能力,播报时由客户端Client自行管理音频焦点,播报前申请音频焦点,…...

ArcGIS Maps SDK for JavaScript:使用图层过滤器只显示FeatureLayer的部分要素

文章目录 引言1 需求场景分析2精确过滤实现方案2.1 基础过滤语法2.2 动态过滤实现 3 模糊查询进阶技巧3.1 LIKE操作符使用3.2 特殊字段处理 4. 性能优化与注意事项4.1 服务端vs客户端过滤4.2 最佳实践建议 5 常见问题解答 引言 在地图应用开发中&#xff0c;图层过滤是常见的需…...

深入理解二叉搜索树:原理到实践

1.二叉搜索树的概念 ⼆叉搜索树⼜称⼆叉排序树&#xff0c;它或者是⼀棵空树&#xff0c;或者是具有以下性质的⼆叉树 若它的左树不为空&#xff0c;则左子树上所有节点的值都小于或等于根节点的值。若它的右树不为空&#xff0c;则右子树上所有节点的值都大于或等于根节点的…...

测试W5500的第11步_使用ARP解析IP地址对应的MAC地址

本文介绍了基于W5500芯片的ARP协议实现方法&#xff0c;详细阐述了ARP请求与回复的工作机制。ARP协议通过广播请求和单播回复实现IP地址与MAC地址的映射&#xff0c;确保局域网设备间的可靠通信。文章提供了完整的STM32F10x开发环境下的代码实现&#xff0c;包括网络初始化、SP…...

终极数据结构详解:从理论到实践

终极数据结构详解&#xff1a;从理论到实践 我将从 底层原理、时间复杂度、空间优化、实际应用 和 代码实现 五个维度&#xff0c;彻底解析数据结构。内容涵盖&#xff1a; 线性结构&#xff08;数组、链表、栈、队列&#xff09;非线性结构&#xff08;树、图&#xff09;高…...

STM32实战: CAN总线数据记录仪设计方案

以下是基于STM32的CAN总线数据记录仪/转发器的设计与实现方案&#xff0c;结合了核心功能和进阶需求&#xff1a; 系统架构 graph TBA[CAN总线] -->|CAN_H/CAN_L| B(STM32 bxCAN)B --> C[数据处理核心]C --> D[SD卡存储<br>FATFS文件系统]C --> E[串口输出…...

【k8s】k8s集群搭建

k8s集群搭建 一、环境准备1.1 集群类型1.2 安装方式1.3 主机规划1.4 环境配置1.4.1 说明1.4.2 初始化1.4.3 关闭防火墙和禁止防火墙开机启动1.4.4 设置主机名1.4.5 主机名解析1.4.6 时间同步1.4.7 关闭selinux1.4.8 关闭swap分区1.4.9 将桥接的IPv4流量传递到iptables的链1.4.1…...

60天python训练计划----day45

DAY 45 Tensorboard使用介绍 知识点回顾&#xff1a; tensorboard的发展历史和原理tensorboard的常见操作tensorboard在cifar上的实战&#xff1a;MLP和CNN模型 之前的内容中&#xff0c;我们在神经网络训练中&#xff0c;为了帮助自己理解&#xff0c;借用了很多的组件&#x…...

Python训练营打卡Day46(2025.6.6)

知识点回顾&#xff1a; 不同CNN层的特征图&#xff1a;不同通道的特征图什么是注意力&#xff1a;注意力家族&#xff0c;类似于动物园&#xff0c;都是不同的模块&#xff0c;好不好试了才知道。通道注意力&#xff1a;模型的定义和插入的位置通道注意力后的特征图和热力图 i…...

C# Wkhtmltopdf HTML转PDF碰到的问题

最近碰到一个Html转PDF的需求&#xff0c;看了一下基本上都是需要依赖Wkhtmltopdf&#xff0c;需要在Windows或者linux安装这个可以后使用。找了一下选择了HtmlToPDFCore&#xff0c;这个库是对Wkhtmltopdf.NetCore简单二次封装&#xff0c;这个库的好处就是通过NuGet安装HtmlT…...

Vue3 (数组push数据报错) 解决Cannot read property ‘push‘ of null报错问题

解决Cannot read property ‘push‘ of null报错问题 错误写法 定义变量 <script setup>const workList ref([{name:,value:}])</script>正确定义变量 <script setup>const workList ref([]) </script>解决咯~...

Lifecycle 核心原理面试回答

1. 核心目标与设计思想 解耦生命周期管理&#xff1a; 将 Activity/Fragment 的生命周期回调逻辑从视图控制器中剥离&#xff0c;让业务组件&#xff08;如 Presenter, Repository 封装&#xff09;能独立感知生命周期。 状态驱动&#xff1a; 将离散的生命周期事件 (ON_CREAT…...