java浏览器预览文件,使用javascript下载pdf,浏览器打开预览pdf格式

本文介绍了如何处理前端下载PDF文件时,避免文件在浏览器中直接打开的情况。通过修改文件的MIME类型为'application/octet-stream'并添加'Content-Disposition: attachment'头,可以强制文件下载。前端实现方法包括使用fetch API获取文件,转换为Blob对象,然后创建URL并利用a标签触发下载。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在做需求过程中我们大概率会遇到在浏览器中下载文件的需求

第一种是通过 window 对象的 open 方法进行操作,将文件 url 直接在浏览器中打开即可下

window.open(url)

第二种是通过 a 标签,设置 href 为 url 值,点击 a 标签即可完成下载。

上面两种文件下载方式都会存在一个问题,就是 pdf 文件会直接在浏览器中打开而不是直接下载

解决方案

这种需求的解决方式就是将PDF文件的 MIME type 改为 application/octet-stream 并加入 Content-Disposition:attachment header,原本的 pdf 文件 MIME type 为 application/pdf,浏览器识别到这个 type 之后会自动在浏览器打开,所以说我们在这里修改 type 即可。

修改的方法有两种,一种是在后端进行修改,上传文件或者返回文件的时候进行操作,但是绝大多数情况下文件都是存储到 cdn 服务器中的,后端也不方便对其进行操作,这个时候就需要前端来修改了。

fetch(url, {

method: 'get',

responseType: 'arraybuffer',

}).then(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)

let a = document.createElement('a');

a.href = link;

a.download = '文件名称';

a.click();

}).catch(err => {

console.error(err)

})

登录后您可以享受以下权益:

×
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值

举报

选择你想要举报的内容(必选)
  • 内容涉黄
  • 政治相关
  • 内容抄袭
  • 涉嫌广告
  • 内容侵权
  • 侮辱谩骂
  • 样式问题
  • 其他
点击体验
DeepSeekR1满血版
程序员都在用的中文IT技术交流社区

程序员都在用的中文IT技术交流社区

专业的中文 IT 技术社区,与千万技术人共成长

专业的中文 IT 技术社区,与千万技术人共成长

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

客服 返回顶部