关注它,不迷路。
本文章中所有内容仅供学习交流,不可用于任何商业用途和非法用途,否则后果自负,如有侵权,请联系作者立即删除!
1. 需求分析
现在越来越多的网站加入了混淆代码,当我们还原某些代码后,难免会剩下一些垃圾代码,比如没有被使用的局部变量,if语句不执行的情况等。因此,写个插件用来清除它们还不影响代码的执行逻辑,那最好不过了。
2. 混淆代码
还原前:
!function() {
function a() {
console.log("Ast is Good!");
}
function b() {
a();
}
function c() {
b();
}
function d() {
c();
}
console.log('666');
}();
还原后:
!function () {
console.log('666');
}();
3. 插件编写思路
一个函数定义,如果没有被调用,即使被更改了,依然可以删除,这是它与变量定义不同的地方。
如果是全局函数,则要考虑其他的js文件是否调用,因此建议保留,如果你确认需要删除,不判断它是否为全局函数即可。
如果它被引用,可以检测是否是函数内部引用的,如果仅仅只是在内部引用,依然可以删除。
如果没有被(外部)引用,则直接进行删除。这个时候要注意其他函数定义的引用次数变化,因此,你需要重新再遍历一次该插件。即递归。
为啥不用 scope.crawl() ,一是递归调用它,运行速度比较慢,二是即使用了,也没效果。
4. 插件源码
https://t.zsxq.com/07ZvFYbUn
今天的文章就分享到这里,后续分享更多的技巧,敬请期待。
欢迎加入知识星球,学习更多AST和爬虫技巧。