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 下载并保存为中文名
相关推荐
Genie cloud7 分钟前
1Panel SSL证书申请完整教程
服务器·网络协议·云计算·ssl
24zhgjx-lxq42 分钟前
华为ensp:MSTP
网络·安全·华为·hcip·ensp
ling___xi1 小时前
《计算机网络》计网3小时期末速成课各版本教程都可用谢稀仁湖科大版都可用_哔哩哔哩_bilibili(笔记)
网络·笔记·计算机网络
REDcker1 小时前
Linux 文件描述符与 Socket 选项操作详解
linux·运维·网络
Up九五小庞1 小时前
用arpspoof实现100%批量切断192.168.110.10 - 192.168.110.100 断网(双向欺骗)--九五小庞
网络·开源
躺柒1 小时前
读数字时代的网络风险管理:策略、计划与执行04风险指引体系
大数据·网络·信息安全·数字化·网络管理·网络风险管理
独角鲸网络安全实验室2 小时前
本地信任成“致命漏洞”:数千Clawdbot Agent公网裸奔,供应链与内网安全告急
网络·网关·安全·php·漏洞·clawdbot·信任机制漏洞
ai_xiaogui2 小时前
Tailscale实现家庭与公司网络双向通信教程:子网路由配置详解
网络·tailscale·双向通信·子网路由配置详解·tailscale双向互访
mftang3 小时前
现代互联网安全的基石: SSL/TLS技术介绍
服务器·网络·ssl
坐怀不乱杯魂3 小时前
Linux网络 - 网络层
linux·服务器·网络