Go标准库archive/zip和archive/tar可实现压缩解压:ZIP一体化打包压缩,TAR需搭配gzip;需手动处理目录遍历、路径标准化(filepath.ToSlash)、安全校验(防路径遍历)、资源关闭及错误处理。

Go 语言标准库提供了 archive/zip 和 archive/tar 等包,能方便地实现文件的压缩与解压,无需第三方依赖。核心在于理解归档(打包)和压缩(如 deflate)是两个步骤——ZIP 是打包+压缩一体化,而 TAR 通常只打包,需搭配 gzip/bzip2 等进一步压缩。
使用 zip 包压缩多个文件或目录
Go 的 archive/zip 支持创建 ZIP 文件,但不直接支持递归遍历目录,需手动处理路径和文件读取。关键点:打开 *zip.Writer,为每个文件创建 zip.FileHeader,注意设置 ModTime 和 Method(如 zip.Deflate),再通过 io.Copy 写入内容。
- 对普通文件:用
os.Open读取,写入w.Writer - 对目录:创建 header 时设
FileHeader.IsDir() == true,并以/结尾,然后调用w.CreateHeader(不写内容) - 路径需转为 ZIP 标准格式(用
filepath.ToSlash避免 Windows 反斜杠问题)
使用 zip 包解压 ZIP 文件
解压更简单:用 zip.OpenReader 打开 ZIP,遍历 r.File 列表。对每个 *zip.File,调用 f.Open() 获取 reader,再根据 f.IsDir() 创建目录或写入文件。注意检查路径是否安全(防止路径遍历攻击,如 ../../etc/passwd),建议用 filepath.Clean(f.Name) 并确保不以 .. 开头。
- 先
os.MkdirAll(filepath.Dir(dstPath), 0755)确保父目录存在 - 跳过非法路径:若
cleanPath != f.Name || strings.HasPrefix(cleanPath, ".."),直接跳过 - 写文件前确保不是目录;是目录则只
os.MkdirAll,不写内容
使用 tar + gzip 打包并压缩(.tar.gz)
TAR 本身不压缩,常与 compress/gzip 组合使用。流程是:创建 gzip.Writer → 套上 tar.NewWriter → 遍历文件,为每个条目写 tar.Header(含 Name、Size、Mode、ModTime)→ 调用 tw.Write() 写内容 → 最后 tw.Close() 和 gz.Close()。
95Shop可以免费下载使用,是一款仿醉品商城网店系统,内置SEO优化,具有模块丰富、管理简洁直观,操作易用等特点,系统功能完整,运行速度较快,采用ASP.NET(C#)技术开发,配合SQL Serve2000数据库存储数据,运行环境为微软ASP.NET 2.0。95Shop官方网站定期开发新功能和维护升级。可以放心使用! 安装运行方法 1、下载软件压缩包; 2、将下载的软件压缩包解压缩,得到we
立即学习“go语言免费学习笔记(深入)”;
-
tar.Header.Typeflag设为tar.TypeDir或tar.TypeReg - 文件内容用
io.Copy(tw, file)流式写入,节省内存 - 注意设置
Header.Size(必须准确,否则解压失败)
解压 .tar.gz 文件
顺序相反:先用 gzip.NewReader 包装 reader → 再用 tar.NewReader 解析 → 循环 tr.Next() 获取 header → 按 header.Typeflag 创建目录或写文件。同样需校验路径安全性,权限可从 header.FileInfo().Mode() 提取。
- 目录用
os.MkdirAll(header.Name, header.FileInfo().Mode()) - 普通文件用
ioutil.WriteFile或流式写入(大文件推荐后者) - 跳过设备文件、符号链接等特殊类型(
header.Typeflag == tar.TypeSymlink等)
基本上就这些。标准库能力足够覆盖常见场景,关键是路径处理、安全校验和资源关闭别遗漏。压缩逻辑不复杂,但容易忽略错误检查和边界情况。









