Content-Disposition~强制浏览器保存文件

如果下载的源码需要作者授权,请更换源码。本站免费分享资源不会增加授权

问题

假设你的网站有一张图片 
http://file.test.com/img/login.jpg

使用浏览器访问这个url,默认情况下,浏览器会自动展现这张图片。那么问题来了,如果你目的是想让浏览器默认下载而非展现这张图,怎么办呢?

解决

http header中有一个字段,可以帮你实现这个目的。

Content-Disposition:attachment;

实践

nginx中增加配置

location ~ img {    add_header Content-disposition "attachment";  }

即对所有图片目录的访问,响应头中增加Content-Disposition。

使用浏览器访问 
http://file.test.com/img/login.jpg

chrome的表现:直接下载login.jpg。

ie9表现:提示“您是要打开还是保存来自file.test.com的login.jpg”

为文件换个名字

有时你希望用户侧使用另外的名字保存文件,这时只要增加filename字段即可。

Content-Disposition:attachment;filename=NewnName1

nginx中,你可以这样写

location ~ img {    add_header Content-disposition "attachment;filename=new.jpg";  }123

此时,你再次用浏览器打开http://file.test.com/img/login.jpg时,会发现文件会以new.jpg的名字被保存。

进一步

你可以用php之类的语言,动态输出http头部的Content-disposition字段及文件内容,这样可以根据需要给文件任意命名了。

 收藏 (0) 打赏

入群打赏请备注QQ,购买打赏请备注邮箱

支付宝扫一扫赞助

微信钱包扫描赞助

未经5G云允许不得转载:5G云源码分享网 » Content-Disposition~强制浏览器保存文件

评论 抢沙发

评论前必须登录!

立即登录   注册

5G云源码 更专业 更方便

关于5G云联系我们
切换注册

登录

忘记密码 ?

切换登录

注册

我们将发送一封验证邮件至你的邮箱, 请正确填写以完成账号注册和激活