JS代码压缩

JS代码压缩

本文分享一种技术,用于实现JS代码压缩。

该技术使用LZW算法。

LZW算法又叫“串表压缩算法”,简而言之,通过建立一个字符串表,用较短的代码来表示较长的字符串来实现压缩。

具体的实现方法是:提取原始文本文件数据中的不同字符,基于这些字符创建一个编译表,然后用编译表中的字符的索引来替代原始文本文件数据中的相应字符,从而减少原始数据大小。应该注意的是,我们这里的编译表不是事先创建好的,而是根据原始文件数据动态创建的,解码时还要从已编码的数据中还原出原来的编译表。

JS代实现LZW算法:

//LZW压缩
function lzw_encode(s) {
    let dict = {};
    let data = (s + '').split('');
    let out = [];
    let currChar;
    let phrase = data[0];
    let code = 256;
    for (let i = 1, l = data.length; i < l; ++i) {
        currChar = data[i];
        if (dict[phrase + currChar] != null) {
            phrase += currChar;
        } else {
            out.push(phrase.length > 1 && dict[phrase] || phrase.charCodeAt(0));
            dict[phrase + currChar] = code;
            ++code;
            phrase = currChar;
        }
    }
    out.push(phrase.length > 1 && dict[phrase] || phrase.charCodeAt(0));
    for (let i = 0, l = out.length; i < l; ++i) {
        out[i] = String.fromCharCode(out[i]);
    }
    return out.join('');
}
//LZW解压
function lzw_decode(s) {
    let dict = {};
    let data = (s + '').split('');
    let currChar = data[0];
    let oldPhrase = currChar;
    let out = [currChar];
    let code = 256;
    let phrase;
    for (let i = 1, l = data.length; i < l; ++i) {
        let currCode = data[i].charCodeAt(0);
        if (currCode < 256) {
            phrase = data[i];
        } else {
            phrase = dict[currCode] && dict[currCode] || (oldPhrase + currChar);
        }
        out.push(phrase);
        currChar = phrase.charAt(0);
        dict[code] = oldPhrase + currChar;
        ++code;
        oldPhrase = phrase;
    }
    return out.join('');
}

使用,压缩和解压JS代码:

var str=`
function get_copyright(){
    var domain = "jshaman.com";
    var from_year = 2017;
    var copyright = "(c)" + from_year + "-" + (new Date).getFullYear() + "," + domain;
    return copyright;
}
console.log(get_copyright());
`
console.log("原始长度:",str.length);
console.log("压缩后长度:",lzw_encode(str).length);
console.log("解压后长度:",lzw_decode(lzw_encode(str)).length);
console.log()
console.log("   eval执行压缩代码:")
eval(lzw_decode(lzw_encode(str)));
console.log()
console.log("   constructor执行压缩代码:");
[].constructor.constructor(lzw_decode(lzw_encode(str)))();
console.log()

运行效果:

 

上面同时演示了运行效果。

因为压缩的是JS代码,所以解压后当然运行,才能实现原本JS代码的功能。

实际应用时,如果不想让他人知道使用了什么样的算法,可以再对代码进行混淆加密。

比如这部分代码:

 

用JShaman进行代码加密:

 

加密后的代码成为:

 

加密后的JS代码运行完全不受影响,与之前一样使用:

 

为何要压缩JS代码: 随着Ajax的应用普及,JavaScript已经得到了越来越多程序员的重视。但JS不好调试,代码多了也会严重影响速度,当你在为提高了用户体验,做出了很绚丽的效果而欣喜的时候,是否想过优化一下JS的效率,大网站的JS都做了压缩处理。JS的速度分为两种,下载速度和执行速度。要想JS的下载速度快,就需要尽量减少js文件的大小,另外,把多个js文件合并成一个也能因为减少服务器的响应次数而加快网页下载。 此外,很多程序辛辛苦苦的写出来的javascript代码却被别人随意的剽窃,实为憾事。本软件还可以通过对javascript的变量名称和过程名称进行编码,从而起到混淆ja代码的作用,保护您的劳动成功。 JS代码压缩,基本原理为: 1. 压缩多余的空格和换行符 2. 删除注释,因为注释只对程序员有用而对于浏览网页的最终用户是无用的,删除了可以缩小文件体积 3. 把较长的变量名称和过程名称统一替换为很短的名称,一者可以减小体积,二者还可以减小程序的可读性保护自己的劳动成功。 JS代码压缩工具: 现有的JS代码压缩工具都是网页版的,例如ESC,shrinksafe等,他们都是在网页上用js本身实现对代码压缩。由于网页的局限性,很难很好的管理压缩任务。聚问网络开发js压缩专家(JsPacker)v1.0 是同功能的桌面程序,并且是绿色软件,使用起来更加方便。 软件名称:js压缩专家 v1.0 (英文名称:JsPacker) 软件简介:可以高效的压缩Javascript脚本文件缩短网页显示时间,可以混淆代码保护知识产权,还可以把多个文件合并压缩。产生的代码兼容IE,FireFox等常用浏览器。本软件可免费使用和转载,但严禁用于商业用途。 本软件不同于网络上已有的同类软件,现有的都是网页版的,本软件是完全的绿色软件,下载后直接运行即可,界面很简单。包括压缩率选项,压缩文件设置,压缩文件管理,js压缩结果预览等。 软件大小:296KB
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值