前端js实现根据文件url批量压缩下载成zip包

1、安装依赖

npm install jszip --save / yarn add jszip -S

npm install file-saver --save / yarn add file-saver -S

2、引入

import JSZip from 'jszip'

import FileSaver from 'file-saver'

import axios from 'axios';

3、实现

const dataSouce = [
    {
        fileUrl: 'http://dev.imuyuan.com/file/fetch/v1/7lGQFepQllMVl8ZTbMftS5',
        fileName: '文件一'
    },
    {
        fileUrl: 'http://dev.imuyuan.com/file/fetch/v1/5SNVT9QI6g791pHBSjLRsE',
        fileName: '文件二'
    },
    {
        fileUrl: 'http://dev.imuyuan.com/file/fetch/v1/4m0Qy7k1qMrh8QIA8DbHce',
        fileName: '文件三'
    },
    {
        fileUrl: 'http://dev.imuyuan.com/file/fetch/v1/2GCtdxKkrlVTSHAt00sHXJ',
        fileName: '文件四'
    },
]

const Index = () => {

    // 将文件 url 格式转换为 Bolb 类型格式 或者 arraybuffer 格式
    const getFileData = (fileUrl: string) => {
        return new Promise((resolve, reject) => {
            axios(fileUrl, {
                method: 'GET',
                responseType: 'blob'  // 返回的数据会被强制转为blob类型 ,转换成arraybuffer 也行
            }).then((res) => {
                console.log('res', res)
                resolve(res)
            }).catch(error) => {
                reject(error)
            }
        })
    }
    
    // 批量打包下载事件
    const handleBatchDown = async () => {
        const zip = new JSZip() // 创建实例对象
        const promises: any = []
        dataSource.forEach((item: any) => {
            const promise = getFile(item.fileUrl).then((res: any) => {
                const fileName = item.fileName + ''
                // 创建文件用file(),创建文件夹用 floder()
                zip.file(fileName, res, {binary: true})
            })
            promises.push(promise)
        })
        
        /** 
            Promise.all 方法用于将多个 Promise 实例,包装成一个新的 Promise 实例,
            只有当all([p1, p2, p3]) 中的每一个 Promise 实例的状态都变成 fulfilled, Promise.all()的状态才会变成 fulfilled,此时  p1, p2, p3 的返回值组成一个数据,传给 Promise.all()的回调函数
            只要 p1, p2, p3 中任何一个被 rejected,  Promise.all() 的状态就会变成 rejected,此时第一个被 rejected 的实例的返回值,会传给 Promise.all()的回调函数。
            
            在上面的代码中,promises 数组中的每一个元素,都是 Promise 实例,所以需要用到 Promise.all()    
        */
        
        // 生成 zip 文件
        Promise.all(promises).then(() => {
            // 生成zip 文件
            zip.generateAsync({
                type: 'blob',
                compression: 'DEFLATE',  // STORE: 默认不压缩, DEFLATE:需要压缩
                 compressionOptions: {
                       level: 9          // 压缩等级 1~9   1 压缩速度最快, 9 最优压缩方式
                 }
            }).then((res: any) => {
                FileSaver.saveAs(res, '测试.zip') // 使用FileSaver.saveAs保存文件,文件名可自定义
            })
        })
        
    }
    
    return (
        <div>
            <Button onClick = {handleBatchDown}>批量打包下载文件</Button>
        </div>
    )
}

export default memo(Index)
 

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
好的,这个问题需要用到Java的IO流和压缩库。大致思路如下: 1. 读取txt文件中的每一行,获取文件URL路径。 2. 根据URL路径创建一个URLConnection对象,获取该文件的输入流。 3. 将输入流写入本地的一个文件中,可以用FileOutputStream实现。 4. 遍历完所有的URL路径后,将所有下载文件压缩一个zip,可以用ZipOutputStream实现。 下面是一个简单的实现代码,仅供参考: ```java import java.io.*; import java.net.*; import java.util.zip.*; public class FileDownloader { public static void main(String[] args) throws IOException { String urlFile = "urls.txt"; // 存放URL路径的文件 String downloadDir = "downloads"; // 下载文件存放的目录 String zipFile = "downloads.zip"; // 压缩后的zip // 创建下载目录 File dir = new File(downloadDir); if (!dir.exists()) { dir.mkdir(); } // 读取URL路径文件 BufferedReader reader = new BufferedReader(new FileReader(urlFile)); String line; while ((line = reader.readLine()) != null) { // 创建URL连接 URL url = new URL(line); URLConnection conn = url.openConnection(); // 获取文件名 String fileName = url.getFile(); fileName = fileName.substring(fileName.lastIndexOf('/') + 1); // 创建文件输出流 FileOutputStream fos = new FileOutputStream(new File(downloadDir, fileName)); // 复制输入流到输出流 InputStream is = conn.getInputStream(); byte[] buffer = new byte[4096]; int len; while ((len = is.read(buffer)) != -1) { fos.write(buffer, 0, len); } fos.close(); is.close(); } reader.close(); // 压缩下载文件 FileOutputStream fos = new FileOutputStream(zipFile); ZipOutputStream zos = new ZipOutputStream(fos); for (File file : dir.listFiles()) { byte[] buffer = new byte[4096]; FileInputStream fis = new FileInputStream(file); zos.putNextEntry(new ZipEntry(file.getName())); int len; while ((len = fis.read(buffer)) != -1) { zos.write(buffer, 0, len); } zos.closeEntry(); fis.close(); } zos.close(); fos.close(); } } ``` 注意:实际应用中需要加入异常处理和错误提示等逻辑。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值