Erlo

javascript如何打包七牛文件并下载压缩(代码)

时间:2018-08-31   阅读:1444次   来源:php中文网
页面报错
点赞
原文:http://www.php.cn/js-tutorial-409252.html

本篇文章给大家带来的内容是关于javascript如何打包七牛文件并下载压缩(代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

需求分析:根据七牛存储的文件url,把这些文件打包下载。

实现方式,获取文件内容,使用 jszip 进行压缩,最后使用 file-saver 进行保存下载。

需要注意两点:

1:某些 web框架(比如 laravel) 会给 axios 配置上默认的请求头。在请求文件时需要去掉默认的请求头,同时设置Content-type 为'application/x-www-form-urlencoded; charset=UTF-8', 否则会导致跨域。

2:response type 是 binary,文件是以二进制的方式传过来的,所以要设置 responseType 为 blob.

部分代码示例:

import JSZip from 'jszip'
import filesaver from "file-saver"
var zip = new JSZip();
// 我用的 axios 需要把这两个 header 删掉
delete window.axios.defaults.headercnblogs.common['X-Requested-With'];
delete window.axios.defaults.headercnblogs.common['X-CSRF-TOKEN'];
axios.get(file.file_url, {
    responseType: 'blob',
    headers : {
      'Content-Type' : 'application/x-www-form-urlencoded; charset=UTF-8'
    }
  }).then(function(res){
    var response = res.data;
    zip.file(file.id + "_" + file.name, response, {binary: true});
    // do your job
  }).catch(function(error){
    console.error(error);
  });

保存:

zip.generateAsync({
  type: "blob"
}).then((blob) => {
  filesaver.saveAs(blob, this.current_zip_name)
}, (err) => {
  alert('导出失败')
});

相关推荐:

七牛mkzip压缩中文文件名乱码

实例详解Vue 中批量下载文件并打包方法

相关推荐

提交留言

评论留言

还没有评论留言,赶紧来抢楼吧~~

每日一笑关闭


	   
	   
	   
评论一下
返回顶部

给这篇文章打个标签吧~

棒极了 糟糕透顶 好文章 PHP JAVA JS 小程序 Python SEO MySql 确认