• 技术文章 >web前端 >js教程

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

    不言不言2018-08-31 10:43:29原创1041
    本篇文章给大家带来的内容是关于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.headers.common['X-Requested-With'];
    delete window.axios.defaults.headers.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 中批量下载文件并打包方法

    以上就是javascript如何打包七牛文件并下载压缩(代码)的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:javascript
    上一篇:javascript面向对象是什么?js中对象的理解 下一篇:js如何实现页面的滚动条下拉时加载更多(附代码)
    千万级数据并发解决方案

    相关文章推荐

    • PHP整合七牛实现上传文件_php技巧• javascript - 七牛js上传时如何在点击某个按钮之后才初始化uploader• javascript - 为何我上传至七牛的文件都没有文件名呢?• javascript - 上传视频到七牛,切片成功,七牛空间也能看到视频,但是,为什么会报转码处理404• WeCenter是什么
    1/1

    PHP中文网