电话
400 9058 355
http.ServeFile是最简静态文件下载方案,但需手动设Content-Disposition强制下载、用filepath.Clean防遍历漏洞;生产环境推荐自定义Handler实现权限校验、Range支持与精准缓存控制。
http.ServeFile 快速提供静态文件下载直接暴露文件路径给客户端下载,http.ServeFile 是最简方案,但仅适用于固定路径、无需权限控制的场景。它会自动设置 Content-Type 和 Last-Modified,但不会设置 Content-Disposition,浏览器可能选择内嵌而非下载。
filepath 是绝对路径,相对路径易导致 404 或目录遍历漏洞w.Header().Set("Content-Disposition", "attachment; filename=\"myfile.zip\"")
http.ServeFile 不校验文件是否存在,不存在时返回 404;但若路径含 .. 且未清理,可能被用于读取任意文件(如 /etc/passwd)filepath.Clean 并校验前缀绕过 http.ServeFile 的限制,自己读取文件、写入响应体,能精确控制缓存策略、分块传输、权限校验和断点续传支持。
os.Open 打开文件,再调用 stat, err := f.Stat() 获取大小和修改时间w.Header().Set("Content-Length", strconv.FormatInt(stat.Size(), 10))
w.Header().Set("Last-Modified", stat.ModTime().UTC().Format(http.TimeFormat))
w.Header().Set("Content-Disposition", "attachment; filename=\""+filename+"\"")io.Copy 流式写入,避免全量加载大文件到内存:io.Copy(w, f)
Range 请求(如断点续传),不能直接用 io.Copy,得解析 Range 头、用 f.ReadAt 跳读,并返回 206 Partial Content
缓存行为由客户端决定,服务端只能通过响应头引导。对下载类资源,通常倾向「强缓存 + 校验」组合,而非完全禁用缓存。
v1.2.0/app-linux-amd64)适合用 Cache-Control: public, immutable, max-age=31536000
Cache-Control: no-store 或 no-cache,并配合 ETag 校验ETag,推荐基于文件内容哈希(如 sha256.Sum256)而非修改时间,避免内容未变但时间戳更新导致误判Expires 已被现代实践弱化,优先用 Cache-Control;两者共存时以 Cache-Control 为准http.FileServer 不适合直接用于下载路由
http.FileServer 是为静态站点服务设计的,其默认行为与下载需求存在本质冲突:它把路径映射为本地目录结构,并允许目录列表、忽略 Content-Disposition、不校验请求方法(如接受 POST 到文件路径)。
http.Dir 不过滤 ..),除非显式包装为安全封装器Content-Type,某些二进制文件可能被识别为 text/plain 导致浏览器乱码渲染FileServer 自行实现 HandlerETag,若没处理 If-None-Match 请求头并返回 304 Not Modified,客户端仍会重复下载整个文件。这个分支必须显式编码,Go 的标准库不会自动帮你做。
邮箱:8955556@qq.com
Q Q:8955556
本文详解如何将Go官方present工具(用于生成HTML5...
PySNMP在不同版本中对SNMP错误状态(errorSta...
time.Sleep仅阻塞当前goroutine,其他gor...
PHPfopen()创建含特殊符号的文件名失败主因是操作系统...
WooCommerce中通过代码为分组产品动态聚合子商品的属...
io.ReadFull返回io.ErrUnexpectedE...
本文详解Yii2中控制器向视图传递ActiveRecord数...
本文详解为何通过wp_set_object_terms()为...
Pytest中使用@mock.patch类装饰器会导致补丁泄...
带缓冲的channel是并发安全的FIFO队列;make(c...