JavaScript如何实现隐式流完整性控制

JavaScript如何实现隐式流完整性控制

小编给大家分享一下JavaScript如何实现隐式流完整性控制,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

隐式流完整性控制

当我们尝试对代码进行反混淆处理时,我们首先会尝试重命名某些函数或变量,但是在JavaScript中我们可以检测函数名是否被修改过,或者说我们可以直接通过堆栈跟踪来获取其原始名称或调用顺序。

JavaScript如何实现隐式流完整性控制

arguments.callee.caller可以帮助我们创建一个堆栈跟踪来存储之前执行过的函数,演示代码如下:

functiongetCallStack(){varstack="#",total=0,fn=arguments.callee;while((fn=fn.caller)){stack=stack+""+fn.name;total++}returnstack}functiontest1(){console.log(getCallStack());}functiontest2(){test1();}functiontest3(){test2();}functiontest4(){test3();}test4();

注意:源代码的混淆程度越强,这个技术的效果就越好。

以上是“JavaScript如何实现隐式流完整性控制”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注恰卡编程网行业资讯频道!

发布于 2022-03-18 22:52:19
收藏
分享
海报
0 条评论
29
上一篇:JavaScript如何使用代理对象 下一篇:JavaScript如何使用DevTools检测
目录

    0 条评论

    本站已关闭游客评论,请登录或者注册后再评论吧~

    忘记密码?

    图形验证码