为了账号安全,请及时绑定邮箱和手机立即绑定

vue flask文件下载,两步搞定

标签:
Flask

    今天给大家说一说vue flask文件下载的方法,具体如下:

1,首先定义后端flask接口,将文件转换为二进制流

@app.route('/download', methods=['GET'])

def download():

    file = open("./upload/test.zip", "rb").read()

    response = make_response(file)

    return response

2,前端发送请求获取数据

(1)首先可以直接通过a标签发送请求如下,服务器运行在本地5000端口

<a href="http://localhost:5000/download">下载数据</a>

(2)也可以通过fetch和axios发送请求

    fetch:因为fetch包裹了两层promise,第一层获取响应同时调用其blob方法将数据转为blob,第二层接收blob,并创建a标签实现下载

fetch('http://localhost:5000/download', {

  method: 'GET'

})

  .then((res) => {

    return res.blob()

  })

  .then(data => {

    const blobUrl = window.URL.createObjectURL(data)

    const a = document.createElement('a')

    a.style.display = 'none'

    a.download = 'test.zip'

    a.href = blobUrl

    a.click()

  })

    axios由于vue项目用axios更多,也可以使用axios,注意get请求的config是第二个参数进行配置的,而post是第三个;并且这里需要配置responseType为blob

this.$https.get('/download', {

  responseType: 'blob'

}).then((res) => {

  const blobUrl = window.URL.createObjectURL(res.data)

  const a = document.createElement('a')

  a.style.display = 'none'

  a.download = 'test.zip'

  a.href = blobUrl

  a.click()

})

    好啦,以上便是关于vue flask文件下载,两步搞定的全部内容,更多内容可关注慕课网其他文章~

点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消