【Auto.js】[zip压缩] 将文件夹压缩成zip包

简介: 【Auto.js】[zip压缩] 将文件夹压缩成zip包

将一个文件夹压缩成一个zip包,可应用于项目文件夹打包成zip, 文件夹过滤了目录中的空文件夹,因此,空文件夹不会被打包到zip包中.

由于本人JS知识有限,JAVA也不懂, 导致该函数, 打包大型文件时, 非常慢,性能低下. 如果@admin 有好的方法, 可以发一下, 谢谢.


importClass(java.io.File);
importClass(android.net.Uri);
importClass(java.lang.System);
importClass(java.io.FileInputStream);
importClass(java.io.FileOutputStream);
importClass(java.io.OutputStream);
importClass(java.util.zip.ZipEntry);
importClass(java.util.zip.ZipOutputStream);
var srcPath = "/sdcard/脚本/";
var zipFilePath = "/sdcard/autoJS.zip"
dirToZip(srcPath, zipFilePath);
/**
 * 将一个文件夹压缩成zip包 
 * @param {string} srcDir 要压缩的文件夹(绝对路径)
 * @param {string} out 压缩后输出的zip文件(绝对路径)
 */
function dirToZip(srcDir, out) {
    var zipPath = new FileOutputStream(new File(out));
    var path = new File(srcDir);
    var srcDirParent = path.getParent();
    var start = System.currentTimeMillis();
    var zos = null ;
    try {
        zos = new ZipOutputStream(zipPath);
        var sourceFile = new File(srcDir);
        compress(sourceFile, zos, sourceFile.getName());
        var end = System.currentTimeMillis();
        log("压缩完成,耗时:" + (end - start) +" ms");
    } catch (e) {
        throw ("zip error from ZipUtils"+e);
    } finally {
        if(zos != null){
            try {
                zos.close();
            } catch (e) {
                log(e);
            }
        }
    }
    function compress(sourceFile, zos, name) {
        if(files.isFile(sourceFile)){
            zos.putNextEntry(new ZipEntry(name));
            var len;
            var put = new FileInputStream(sourceFile);
            while ((len = put.read()) != -1){
                zos.write(len);
            }
            zos.closeEntry();
            put.close();
        } else {
            var listFiles = getListFilePath(sourceFile);
            for (let i in listFiles) {
                var fileName = new File(listFiles[i]);
                compress(listFiles[i], zos, fileName.getParent().split(srcDirParent)[1] + "/" + fileName.getName());
            }
        }
    }
    function getListFilePath(i) {
        i = i.toString();
        function r(i) {
            var e = files.listDir(i);
            for (var s in e) {
                if ("/" == i.charAt(i.length - 1)) var a = i + e[s]; else var a = i + "/" + e[s];
                files.isDir(a) ? r(a) : t.push(a);
            }
        }
        var t = [];
        return r(i), t;
    }
}


//解压zip文件

com.stardust.io.Zip.unzip(new java.io.File("解压zip文件的路径"), new java.io.File("要把zip解压到 某个文件夹的路径"));

相关文章
|
7月前
|
前端开发 JavaScript 安全
从前端性能优化角度谈JavaScript代码压缩与混淆
本文从前端性能优化的角度出发,探讨了JavaScript代码压缩与混淆的重要性及实现方式,通过分析不同压缩混淆工具的特点和效果,为开发者提供了实用的指导和建议。
|
7月前
|
JavaScript 前端开发
JS将两个数组和合并成数组包对象格式的方法
JS将两个数组和合并成数组包对象格式的方法
106 0
|
3月前
|
JavaScript
Node.js之文件夹的操作
Node.js之文件夹的操作
49 9
|
2月前
|
小程序 JavaScript 前端开发
uni-app开发微信小程序:四大解决方案,轻松应对主包与vendor.js过大打包难题
uni-app开发微信小程序:四大解决方案,轻松应对主包与vendor.js过大打包难题
740 1
|
6月前
|
JavaScript Java 测试技术
基于springboot+vue.js+uniapp小程序的箱包存储系统附带文章源码部署视频讲解等
基于springboot+vue.js+uniapp小程序的箱包存储系统附带文章源码部署视频讲解等
50 5
|
3月前
|
缓存 JavaScript 中间件
优化Express.js应用程序性能:缓存策略、请求压缩和路由匹配
在开发Express.js应用时,采用合理的缓存策略、请求压缩及优化路由匹配可大幅提升性能。本文介绍如何利用`express.static`实现缓存、`compression`中间件压缩响应数据,并通过精确匹配、模块化路由及参数化路由提高路由处理效率,从而打造高效应用。
192 16
|
4月前
|
JavaScript 前端开发 安全
JS 混淆解析:JS 压缩混淆原理、OB 混淆特性、OB 混淆JS、混淆突破实战
JS 混淆解析:JS 压缩混淆原理、OB 混淆特性、OB 混淆JS、混淆突破实战
228 2
|
4月前
|
机器学习/深度学习 JavaScript
node.js实现遍历所有文件夹里面的js文件,提取所有的url
node.js实现遍历所有文件夹里面的js文件,提取所有的url
|
4月前
|
资源调度 JavaScript 前端开发
如何大幅减少 Vue.js 中的包大小和加载时间,提升用户体验!
如何大幅减少 Vue.js 中的包大小和加载时间,提升用户体验!
|
6月前
|
自然语言处理 JavaScript 前端开发
JS代码是如何被压缩的
JS代码是如何被压缩的
43 1