如何使 pdf 文件在浏览器里面直接下载而不是打开
2020-08-10 20:28
701 查看
前言
在做需求过程中我们大概率会遇到在浏览器中下载文件的需求,如果仅仅是这个要求的话很简单,有如下两种解决方式。
第一种是通过 window 对象的 open 方法进行操作,将文件 url 直接在浏览器中打开即可下载。
window.open('url')
第二种是通过 a 标签,设置 href 为 url 值,点击 a 标签即可完成下载。
<a href='url' download='文件名'></a>
但是上面两种文件下载方式都会存在一个问题,就是 pdf 文件会直接在浏览器中打开而不是直接下载,效果如下:
解决方案
这种需求的解决方式就是将PDF文件的 MIME type 改为
application/octet-stream并加入
Content-Disposition:attachmentheader,原本的 pdf 文件 MIME type 为
application/pdf,浏览器识别到这个 type 之后会自动在浏览器打开,所以说我们在这里修改 type 即可。
修改的方法有两种,一种是在后端进行修改,上传文件或者返回文件的时候进行操作,但是绝大多数情况下文件都是存储到 cdn 服务器中的,后端也不方便对其进行操作,这个时候就需要前端来修改了。
处理代码如下:
/** * @deprecated 下载文件 * @param {string} url * @param {string} filename */ handleFileDownload = (url, filename) => { // 创建 a 标签 let a = document.createElement('a'); a.href = url; a.download = filenam 12cc e; a.click(); } /** * @deprecated 处理 pdf url,使其不在浏览器打开 * @param {string} url */ handlePdfLink = (url, filename) => { fetch(url, { method: 'get', responseType: 'arraybuffer', }) .then(function (res) { if (res.status !== 200) { return res.json() } return res.arrayBuffer() }) .then((blobRes) => { // 生成 Blob 对象,设置 type 等信息 const e = new Blob([blobRes], { type: 'application/octet-stream', 'Content-Disposition':'attachment' }) // 将 Blob 对象转为 url const link = window.URL.createObjectURL(e) handleFileDownload(link, filename) }).catch(err => { console.error(err) }) }
这样修改修改代码的话就可以实现在浏览器中下载。效果如下
相关文章推荐
- 如何在html中下载pdf等文件而不是直接打开
- 轻松下载.pdf文件(直接下载,而不是在IE浏览器里面打开)
- 轻松下载.pdf文件(直接下载,而不是在IE浏览器里面打开)
- PHP实现点击a标签的href做链接时,直接保存文件(任何类型),而不是通过浏览器直接打开下载的文件
- 默认点击下载pdf等文件而不是在浏览器中打开
- 在java的WEB项目如何防止浏览器直接打开下载的文件
- html5链接直接下载文件 不是直接打开 如pdf, doc 等
- 设置ngnix下的文件在浏览器端直接下载而不是被浏览器默认打开
- php -- PHP实现点击a标签的href做链接时,直接保存文件(任何类型),而不是通过浏览器直接打开下载的文件
- 如何控制url静态文件png,jpeg,jpg,pdf不在浏览器预览而是直接下载
- 怎么解决点击下载Csv文件时在浏览器里面打开,而不是下载
- 文件下载 浏览器直接打开文件而不是保存 相关问题
- JavaWeb文件下载,提示用户保存而不是让浏览器直接打开
- 记录一下:上传到服务器上的pdf 文件直接下载而非在浏览器里打开
- 如何使浏览器默认下载文件而不是打开文件
- Java 下载文件,浏览器直接打开,并且PDF再次点击下载时,文件名称设置正确
- 关于response返回的文件格式和下载如何在浏览器中直接打开文件
- 让谷歌浏览器直接下载pdf而不是在浏览器中打开
- 在文件下载的时候将其保存而不是直接在浏览器上打开!
- .net C# 实现点击下载PDF文件(通知浏览器打开下载对话框) 不是直接打开