美文网首页vue学习
vue-cil2 代码混淆

vue-cil2 代码混淆

作者: 张xiao蛋 | 来源:发表于2020-11-17 13:27 被阅读0次

1、在webpack配置目录build下新建JsEncodePlugin.js

// 1、引入必要文件
const fs = require("fs"); //node的文件系统模块,用于读写及操作文件
const path = require("path"); //node提供的一些用于处理文件路径的小工具
var chalk = require("chalk"); //用于向控制台输出带颜色的问题提示
 // 2、模块对外暴露的 js 函数
function JsEncodePlugin(pluginOptions) {
    this.options = pluginOptions;
}
 // 3、原型定义一个 apply 函数,并注入了 compiler 对象
JsEncodePlugin.prototype.apply = function(compiler) {
    const _this = this;
  // 4、挂载 webpack 事件钩子(这里挂载的是 after-emit 事件,在将内存中 assets 内容写到磁盘文件夹之后触发的webpack生命周期钩子)
    compiler.plugin("after-emit",
    function(compilation, callback) {
        // ... 内部进行自定义的编译操作
        // 5、操作 compilation 对象的内部数据
        console.log(chalk.cyan("\n jsencode start.\n"));
        var filePath = path.resolve(__dirname, _this.options.assetsPath); //设置需要加密的js文件路径,_this.options.assetsPath为插件配置中传过来的需要加密的js文件路径
        filterFile(filePath);
        function filterFile(fp) {
            fs.readdir(fp, (err, files) = >{
                //读取该文件路径
                if (err) {
                    console.log(chalk.yellow("读取js文件夹异常:\n" + err.message + "\n"));
                    return;
                }
                files.forEach(filename = >{
                    //遍历该路径下所有文件
                    if (_this.options.jsReg.test(filename)) {
                        //利用正则匹配我们要加密的文件,_this.options.jsReg为插件中传过来的需要加密的js文件正则,用以筛选出我们需要加密的js文件。
                        var filedir = path.resolve(fp, filename);
                        fs.readFile(filedir, "utf-8", (err, data) = >{
                            //读取文件源码
                            if (err) {
                                console.log(chalk.yellow("读取js文件异常:\n" + err.message + "\n"));
                                return;
                            }
                            //调用jjencode函数对源码进行jjencode加密,_this.options.global为插件配置中传过来的加密使用的全局变量名,将在jjencode函数中作为第一个参数传入
                            let result = jjencode(_this.options.global, data);
                            fs.writeFile(filedir, result, err = >{
                                //将加密后的代码写回文件中
                                if (err) {
                                    console.log(chalk.yellow("写入加密后的js文件异常:\n" + err.message + "\n"));
                                    return;
                                }
                                console.log(chalk.cyan("  jsencode complete.\n"));
                            });
                        });
                    }
                });
            });
        }
        //js加密函数
        function jjencode(gv, text) {
            var r = "";
            var n;
            var t;
            var b = ["___", "__$", "_$_", "_$$", "$__", "$_$", "$$_", "$$$", "$___", "$__$", "$_$_", "$_$$", "$$__", "$$_$", "$$$_", "$$$$"];
            var s = "";
            for (var i = 0; i < text.length; i++) {
                n = text.charCodeAt(i);
                if (n == 0x22 || n == 0x5c) {
                    s += "\\\\\\" + text.charAt(i).toString(16);
                } else if ((0x20 <= n && n <= 0x2f) || 0x3a <= n == 0x40 || (0x5b <= n && n <= 0x60) || (0x7b <= n && n <= 0x7f)) {
                    s += text.charAt(i);
                } else if ((0x30 <= n && n <= 0x39) || (0x61 <= n && n <= 0x66)) {
                    if (s) r += '"' + s + '"+';
                    r += gv + "." + b[n < 0x40 ? n - 0x30: n - 0x57] + "+";
                    s = "";
                } else if (n == 0x6c) {
                    // 'l'
                    if (s) r += '"' + s + '"+';
                    r += '(![]+"")[' + gv + "._$_]+";
                    s = "";
                } else if (n == 0x6f) {
                    // 'o'
                    if (s) r += '"' + s + '"+';
                    r += gv + "._$+";
                    s = "";
                } else if (n == 0x74) {
                    // 'u'
                    if (s) r += '"' + s + '"+';
                    r += gv + ".__+";
                    s = "";
                } else if (n == 0x75) {
                    // 'u'
                    if (s) r += '"' + s + '"+';
                    r += gv + "._+";
                    s = "";
                } else if (n < 128) {
                    if (s) r += '"' + s;
                    else r += '"';
                    r += '\\\\"+' + n.toString(8).replace(/[0-7]/g,
                    function(c) {
                        return gv + "." + b[c] + "+";
                    });
                    s = "";
                } else {
                    if (s) r += '"' + s;
                    else r += '"';
                    r += '\\\\"+' + gv + "._+" + n.toString(16).replace(/[0-9a-f]/gi,
                    function(c) {
                        return gv + "." + b[parseInt(c, 16)] + "+";
                    });
                    s = "";
                }
            }
            if (s) r += '"' + s + '"+';

            r = gv + "=~[];" + gv + "={___:++" + gv + ',$$$$:(![]+"")[' + gv + "],__$:++" + gv + ',$_$_:(![]+"")[' + gv + "],_$_:++" + gv + ',$_$$:({}+"")[' + gv + "],$$_$:(" + gv + "[" + gv + ']+"")[' + gv + "],_$$:++" + gv + ',$$$_:(!""+"")[' + gv + "],$__:++" + gv + ",$_$:++" + gv + ',$$__:({}+"")[' + gv + "],$$_:++" + gv + ",$$$:++" + gv + ",$___:++" + gv + ",$__$:++" + gv + "};" + gv + ".$_=" + "(" + gv + ".$_=" + gv + '+"")[' + gv + ".$_$]+" + "(" + gv + "._$=" + gv + ".$_[" + gv + ".__$])+" + "(" + gv + ".$$=(" + gv + '.$+"")[' + gv + ".__$])+" + "((!" + gv + ')+"")[' + gv + "._$$]+" + "(" + gv + ".__=" + gv + ".$_[" + gv + ".$$_])+" + "(" + gv + '.$=(!""+"")[' + gv + ".__$])+" + "(" + gv + '._=(!""+"")[' + gv + "._$_])+" + gv + ".$_[" + gv + ".$_$]+" + gv + ".__+" + gv + "._$+" + gv + ".$;" + gv + ".$$=" + gv + ".$+" + '(!""+"")[' + gv + "._$$]+" + gv + ".__+" + gv + "._+" + gv + ".$+" + gv + ".$$;" + gv + ".$=(" + gv + ".___)[" + gv + ".$_][" + gv + ".$_];" + gv + ".$(" + gv + ".$(" + gv + '.$$+"\\""+' + r + '"\\"")())();';
            //console.log(r);
            return r;
        }
        // 6、执行 callback 回调
        callback();
    });
};
// 暴露 js 函数
module.exports = JsEncodePlugin;

2、然后在webpack.prod.conf.js中使用该插件即可

// 引入插件
const JsEncodePlugin = require("./JsEncodePlugin");
// 在plugins中使用插件
new JsEncodePlugin({
      global: "$",
      jsReg: /^(?!(manifest|vendor)).*\.js$/, // 需要加密的js文件
      assetsPath: "../dist/static/js" // 加密后的js文件存放路径
    }),

相关文章

  • vue-cil2 代码混淆

    1、在webpack配置目录build下新建JsEncodePlugin.js 2、然后在webpack.prod...

  • Android项目的代码混淆

    代码混淆: 代码混淆有两种重要功能。其一,混淆代码。其二,优化代码。有的混淆是根据自己写得代码有关,需要根据异常错...

  • iOS 初探代码混淆(OC)

    iOS 初探代码混淆(OC) iOS 初探代码混淆(OC)

  • ProGuard详解

    Android分享:代码混淆那些事Android代码混淆之混淆规则Android-Dev-Favorites An...

  • Android代码混淆

    待整理。。。 参考: Android混淆从入门到精通 Android代码混淆之混淆规则 代码混淆规则配置文件:pr...

  • iOS-代码混淆加固策略

    iOS-代码混淆加固策略 iOS-代码混淆加固策略

  • iOS应用安全之代码混淆

    iOS应用安全之代码混淆iOS应用安全之代码混淆

  • 代码混淆

    混淆就是在你不想开源代码的时候对代码进行混淆处理,让代码即使被反编译也难以阅读,而且还可以精简编译后程序的大小 一...

  • 代码混淆

    傻瓜式模板

  • 代码混淆

    iOS代码混淆----自动 app 安全(一): 代码混淆防止反编译查看真实的头文件函数声明 iOS安全攻防(二十...

网友评论

    本文标题:vue-cil2 代码混淆

    本文链接:https://www.haomeiwen.com/subject/clyxiktx.html