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 下载并保存为中文名
相关推荐
sailing-data2 小时前
【SE 网络】无线物联网络如何选
网络
skyyx20022 小时前
写给网工新手:子网掩码基本概念和一些计算方法
运维·网络
JY.yuyu2 小时前
OSPF路由协议
网络
kiiila2 小时前
【网络】网络通信模型
网络
2501_915918413 小时前
TCP 抓包分析在复杂网络问题中的作用,从连接和数据流层面理解系统异常行为
网络·网络协议·tcp/ip·ios·小程序·uni-app·iphone
while(1){yan}3 小时前
基础IP协议知识
网络·网络协议·tcp/ip
Turboex邮件分享4 小时前
邮件系统中的消息排队与调度机制分析
网络
zhz52144 小时前
代码之恋(第十五篇:分布式心跳与网络延迟)
网络·分布式·ai·重构·vue·结对编程
元亓亓亓4 小时前
考研408--计算机网络--day9--路由&RIP&OSPF
网络·计算机网络·路由·rip
卓码软件测评4 小时前
第三方APP软件测试机构:【Gatling如何测试移动应用后端API移动网络特性和用户行为模拟】
网络·测试工具·单元测试·测试用例