js下载文件、音频、视频的方式

news/2024/7/19 15:04:05 标签: js, 文件下载

下载文件可以直接通过a标签的href属性直接下载,也可以通过Blob对象转换为文件流进行下载。如果要对大数据量或者需要分片下载、上传等操作,可以考虑Blob对象。同事Blob对象可以对下载过程进行额外操作(拦截等操作),这是a标签直接下载做不到的。

1、a标签下载文件

const downloadFileA = document.createElement('a')
document.body.append(downloadFileA)
downloadFileA.href=`https://xxx`
downloadFileA.download = '下载文件.csv'
// 超链接 target="_blank" 要增加 rel="noopener noreferrer" 来堵住钓鱼安全漏洞。如果你在链接上使用 target="_blank"属性,并且不加上rel="noopener"属性,那么你就让用户暴露在一个非常简单的钓鱼攻击之下。(摘要)
downloadFileA.rel = 'noopener noreferrer'
downloadFileA.click()
document.body.removeChild(downloadFileA)

2、将文件转化为blob对象的二进制数据流下载
Blob对象是一个不可变、原始数据的类文件对象。Blob 表示的不一定是JavaScript原生格式的数据。File 接口基于Blob,继承了 blob 的功能并将其扩展使其支持用户系统上的文件。

axios({
    method: 'get',
    url: `https:/xxx.com${url}`,
    // 必须显式指明响应类型是一个Blob对象,这样生成二进制的数据,才能通过window.URL.createObjectURL进行创建成功
    responseType: 'blob',
}).then((res) => {
    if (!res) {
        return
    }
    // 将lob对象转换为域名结合式的url
    let blobUrl = window.URL.createObjectURL(res.data)
    let link = document.createElement('a')
    document.body.appendChild(link)
    link.style.display = 'none'
    link.href = blobUrl
    // 设置a标签的下载属性,设置文件名及格式,后缀名最好让后端在数据格式中返回
    link.download = '下载文件.csv'
    // 自触发click事件
    link.click()
    document.body.removeChild(link)
    window.URL.revokeObjectURL(blobUrl);
})

3、使用fetch请求进行下载
使用fetch替代a标签,进行下载MP3文件,在浏览器中说使用a标签会直接跳转页面进行播放,达不到下载的目

// 下载服务器的MP3文件
export const downloadMp3 = (filePath) => {
  fetch(filePath).then(res => res.blob()).then(blob => {
    const a = document.createElement('a');
    document.body.appendChild(a)
    a.style.display = 'none'
    // 使用获取到的blob对象创建的url
    const url = window.URL.createObjectURL(blob);
    a.href = url;
    // 指定下载的文件名
    a.download = '语音音频.mp3';
    a.click();
    document.body.removeChild(a)
    // 移除blob对象的url
    window.URL.revokeObjectURL(url);
  });
}

限制的场景也会存在,可能会出现跨域。这时可以让服务端同学进行cores设置,或者转换一下使用JSONP进行跨域请求(只能对GET进行跨域)。

注:若是想在微信环境下进行图片、视频、文件等的下载,以上方式皆不可实现。微信环境下,微信已经做了限制,除了图片可以长按出现保存按钮之外,其他的文件、视频等只能通过其他浏览器进行下载。

转载:https://www.jianshu.com/p/c31c199e1d5e


http://www.niftyadmin.cn/n/1202687.html

相关文章

Windows 10 又在生产环境进行测试?微软:发错了

开发四年只会写业务代码,分布式高并发都不会还做程序员? 微软又双叒叕捅娄子了……最近,不少国外网友反映,自己的Windows 10系统突然收到了几条很诡异的通知,乍一看像是来自恶意软件甚至病毒,结果是微软自…

Vue 仿蚂蚁森林能量球生成获取组件

小编最近刚刚结束了一个需求,需求是这样的:通过做任务生成一定的太阳,领取太阳后达到一定等级树苗进行生长。嗯?听起来是不是觉得很熟悉?是的,小编就想到了蚂蚁森林,不知道各位同学获取到多少个…

深度解析RocketMQ消息发送的高可用设计

2019独角兽企业重金招聘Python工程师标准>>> 微信公众号「后端进阶」,专注后端技术分享:Java、Golang、WEB框架、分布式中间件、服务治理等等。 老司机倾囊相授,带你一路进阶,来不及解释了快上车! 从rocket…

Vue 长按文本复制事件实现

longpress.js export default {install(Vue, options {time: 2000}) {Vue.directive(longpress, {bind: function (el, binding, vNode) {// 确保提供的表达式是函数 if (typeof binding.value ! function) {// 获取组件名称 const compName vNode.contex…

struts 2读书笔记-----Convention插件与“约定”支持

Convention插件的主要特点是“约定优于配置”。 Action的搜索和映射约定 为了能够使用Convention插件,必须在Struts 2 应用中安装Convention插件,即将Struts2-convention-plugin.jar文件复制到Struts 2应用的WEB-INF/lib路径下。 对于convention插件而言…

发送短信验证码-node+阿里云短信

一、准备工作 前端: 表单 提交方式--- get 、post 整体提交 ajax提交 表单验证 正则表达式---不轻易自己写正则,不是不写,一定要考虑好兼容性(全面性)---- 提示信息的选择性 图形验证码 后端进行提供的一张图片&…

微信小程序新分享功能

原分享api: //1、分享到朋友圈 wx.onMenuShareTimeline({title: , // 分享标题link: , // 分享链接,该链接域名或路径必须与当前页面对应的公众号JS安全域名一致imgUrl: , // 分享图标success: function () {// 用户点击了分享后执行的回调函数} },//2、…

Struts 2读书笔记-----通配符的使用

在我们配置Action时&#xff0c;发现struts.xml中的<action…/>的绝大部分都相同。这时我们可以通过使用struts 2 提供的通配符映射机制来处理这个问题。 我们在配置<action …./>时&#xff0c;允许在指定name属性时使用模式字符串&#xff08;即用“*”来代替一个…