• JavaScript正则表达式加密


    正则表达式可以加密吗?

    是的,可以。起码可以确定的是在JavaScript编程中是可以的。

    正则表达式加密有什么用?

    可以隐藏一些重要的、私密的字符串内容,使代码的逻辑、秘密不容易被人窥探。

    正则表达式加密示例

    例如:

    var reg = new RegExp("hello","g");

    这样一行JS代码,经JShaman(JShaman是国内知名的JS代码混淆加密平台)加密后,可以成为:

    var reg=new RegExp("\u0068\u0065\u006c\u006c\u006f","\u0067");

    或者:

    var _0x73d8bg=["hello","g"];var reg=new RegExp(_0x73d8bg[0],_0x73d8bg[1]);

    又或者:

    var _0xf=["97.108.101.101.102.","110."];function _0x3c(str,dy_key){dy_key=9;var i,k,str2="";k=str.split(".");for(i=0;i

    “字面量”形式的正则表达式不能直接加密

    但是,正则表达式有两种写法,上面展示的是以“构造函数”方式进行定义,还有一种“字面量”方式。比如:

    var reg = /hello/g;

    “字面量”方式定义的正则表达式,是不能进行直接加密的。

    在实际的编程中,难免会有“字面量”写法的正则表达式。

    如何实现统一的正则表达式加密呢,即可处理“构造函数”,又可处理“字面量”。

    方法当然是有的,比如:可以把“字量面”转化为“构造函数”。

    把“字量面”正则表达式转化为“构造函数”

    当然不是手动修改,那太不方便了,下面给出一段代码,在NodeJS中将“字面量”正则表达式转化为“构造函数”形式:

    1. const parser = require('@babel/parser')
    2. const traverse = require('@babel/traverse').default
    3. const generator = require('@babel/generator').default
    4. var types = require('@babel/types');
    5. var js_code = `
    6. function a(){
    7. var reg1 = /hello/g;
    8. var reg2 = new RegExp("hello","g");
    9. }
    10. `
    11. var ast = parser.parse(js_code)
    12. traverse(ast, {
    13. RegExpLiteral(path){
    14. //console.log(path.node.pattern, path.node.flags);
    15. console.log(generator(path.node).code);
    16. var pattern = path.node.pattern;
    17. var flags = path.node.flags;
    18. var new_expression = types.newExpression(
    19. types.identifier("RegExp"),
    20. [types.stringLiteral(pattern),types.stringLiteral(flags)]
    21. )
    22. path.replaceWith(new_expression);
    23. }
    24. })
    25. console.log(generator(ast).code);

    代码原理:

    把JS代码,转为化AST(抽象语法树),从AST中检测“字面量”形式的正则表达式,并转化为“构造函数”形式,最后,再将AST转化为JS代码。

    运行效果:

    这样,转化后的正达式,就可以进行统一的混淆加密了。

     

  • 相关阅读:
    阿里8年测试经验,耗时一个月整理的40道自动化测试面试真题(附精准答案解析)足足手写2W字
    数组的基本概念和存储结构
    四足机器人软件架构现状分析
    Boosting Few-Shot Visual Learning with Self-Supervision(代码理解)
    Pimpl 与 unique_ptr 的问题
    GaussDB技术解读丨高级压缩
    测试工作中的测试用例设计
    Spring Boot 注解
    9月22日全球Web3加密行业重大资讯大汇总
    Rokid AR Lite空间计算套装发布,软硬件全面升级推动居家、出行、户外场景大规模应用
  • 原文地址:https://blog.csdn.net/w2sft/article/details/128060495