博文原文地址:Web 文件下载和查看
在浏览器中点击一个文件链接,会被浏览器直接打开或者下载。其实浏览器的行为是可以人为控制的,最简单的方法是使用 HTML5 download Attribute。
<!-- will download as "expenses.pdf" -->
<a href="/files/expenses.pdf" download="expenses.pdf">Download Your Expense Report</a>
这种方式虽然简单,但是兼容性不太好。查看http://caniuse.com/download,我们可以发现 IE 和 Safari 全版本都不支持这个属性。
根本原因在 HTTP Head 中,文件类型由Content-Type
控制。如果 pdf 文件是正确的application/pdf
,浏览器会打开 pdf,而不是去下载,jpg、png 这些文件类型同理。
而下载是由Content-Disposition
来控制的,例如:Content-Disposition: attachment; filename="fname.txt"
。它的意思是将该文件作为附件,并且下载的文件名是 fname.txt.
如果使用 S3,访问文件的 url,可以直接打开。 如果需要下载,使用 AWS 的 api 可以生成相应的 url:
url = object.url_for(:read, response_content_disposition: "attachment; filename=\"#{filename}\"")
相关文档: http://www.w3.org/Protocols/rfc2616/rfc2616-sec19.html http://docs.aws.amazon.com/AWSRubySDK/latest/AWS/S3/S3Object.html