AST反混淆插件|如何还原Object对象里的value值

关注它,不迷路。       

本文章中所有内容仅供学习交流,不可用于任何商业用途和非法用途,否则后果自负,如有侵权,请联系作者立即删除!

1. 需求分析

现在越来越多的js混淆喜欢把一些字面量全部放到一个Ojbect里面,干扰调试。因此,可以写个简单的插件将其取出来。

2. 混淆代码

还原前:

var obj = {"a":123,"b":456,"c":"",};
var res = obj["a"] + obj["a"] + obj["b"] + obj["c"];

还原后:

var res = 123 + 123 + 456 + "";

3. 思路

将Object对象还原需要满足如下条件:

  1. Object对象里面的元素(最好)都是字面量

  2. 定义Object对象的变量没有被改变

编写思路:

  • 大部分Object对象都是通过 var、let、const 来定义的。因此,需要遍历 VariableDeclarator 节点,如果其初始化是赋值语句,即没有使用 var 定义,则可以遍历AssignmentExpression节点,只要有binding就可以。

  • 判断其init节点是否是ObjectExpression类型,并确认其value是否全部是字面量。

  • 判断定义的变量是否被更改,如果被更改,则需要谨慎替换。

  • 通过scope.getBinding来获取引用该变量的地方。

  • 因为Object对象被引用后一般都是MemberExpression表达式,因此找出它的MemberExpression父节点。

  • 拿到property属性,判断是否存在于Object对象的keys中。

  • 如果存在,则直接进行替换。

4. 插件源码

https://t.zsxq.com/07aufeAeA

大家可以通过阅读原文直达链接。

今天的文章就分享到这里,后续分享更多的技巧,敬请期待。

23908301a471e6efadb0d6a04c11fb64.jpeg

欢迎加入知识星球,学习更多AST和爬虫技巧。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值