HTTP之content-disposition

Content-DispositionHTTP 响应头 的一个字段,用来告诉浏览器:"这个响应体(body)是应该直接展示在页面上,还是当成文件下载?如果下载,文件名应该叫什么?"


🔍 一句话解释

Content-Disposition服务器给浏览器的"下载提示" ,告诉浏览器 "别打开,直接保存,文件名是 xxx"


📌 常见格式

1. 在线打开(默认值)
http 复制代码
Content-Disposition: inline

浏览器会 直接打开 文件(比如图片、PDF 直接在标签页显示)。

2. 下载文件
http 复制代码
Content-Disposition: attachment

浏览器会 弹出下载框,不打开文件。

3. 下载并指定文件名
http 复制代码
Content-Disposition: attachment; filename="员工模板.xlsx"

浏览器会 下载文件,并默认保存为"员工模板.xlsx"


⚠️ 中文文件名兼容性

中文文件名 必须编码,否则不同浏览器会乱码。

✅ 正确写法(UTF-8 编码)
http 复制代码
Content-Disposition: attachment; filename*=UTF-8''%E5%91%98%E5%B7%A5%E6%A8%A1%E6%9D%BF.xlsx
  • filename*=UTF-8'' 是 RFC 5987 标准,支持中文
  • %E5%91%98... 是"员工模板.xlsx"的 URL 编码。

🧪 前端如何解析(对应你代码)

js 复制代码
const contentDisposition = res.headers['content-disposition']
// 例子:attachment; filename*=UTF-8''%E5%91%98%E5%B7%A5%E6%A8%A1%E6%9D%BF.xlsx

const filenameMatch = contentDisposition.match(/filename[^;=\n]*=((['"]).*?\2|[^;\n]*)/)
if (filenameMatch && filenameMatch[1]) {
  const filename = decodeURIComponent(filenameMatch[1].replace(/['"]/g, ''))
  // 结果:员工模板.xlsx
}

✅ 总结一句话

场景 Content-Disposition 值示例 浏览器行为
在线打开 inline 直接打开文件
下载文件 attachment 弹出下载框
下载+文件名 attachment; filename*=UTF-8''%E5%91%98%E5%B7%A5.xlsx 下载并保存为中文名
相关推荐
飞凌嵌入式18 小时前
用「EN 18031认证」通关欧盟,这张 “网络安全护照” 已就位
网络·安全·能源
Trouvaille ~18 小时前
TCP Socket编程实战(三):线程池优化与TCP编程最佳实践
linux·运维·服务器·网络·c++·网络协议·tcp/ip
JoySSLLian19 小时前
手把手教你安装免费SSL证书(附宝塔/Nginx/Apache配置教程)
网络·人工智能·网络协议·tcp/ip·nginx·apache·ssl
Zach_yuan19 小时前
自定义协议:实现网络计算器
linux·服务器·开发语言·网络
猫头虎20 小时前
如何解决 OpenClaw “Pairing required” 报错:两种官方解决方案详解
网络·windows·网络协议·macos·智能路由器·pip·scipy
charlotte1024102420 小时前
高并发:关于在等待学校教务系统选课时的碎碎念
java·运维·网络
Zaralike21 小时前
Linux 服务器网络不通排查 SOP(标准操作流程)
linux·服务器·网络
云姜.21 小时前
网络协议----OSI七层网络协议 和 TCP/IP四层(五层)网络协议
网络·网络协议
!chen21 小时前
LabVIEW TCP Server端工具TCP通信
网络·tcp/ip·labview
枷锁—sha21 小时前
【SRC】SQL注入快速判定与应对策略(一)
网络·数据库·sql·安全·网络安全·系统安全