hook检测与保护

承接上篇  当我对一个系统级别的函数进行hook(也就是改写系统级函数)时,在别人写的JavaScript的脚本中会有 对系统级函数的检测(也就是看看系统级函数有没有被改写)

检测的方法有很多种 ,本节专注于讲一种 toString()检测

1. 在没有被改写的时候 

是这个样子的

被改写后

当他们检测出来被改写了就会给我们执行错误的逻辑代码

所以我们就要过掉这个检测

思路一 .  他们用toString()方法调用那我们就直接把tostring方法给改了

我们这样子写呢 虽然说目前显示他和浏览器返回的是一样的 但是这种方式只是在atob 的这个方法

里面定义了一个tostring 的属性 

但是如果他们用到函数原型上面的tostring时 我们就会又被检测到

Function.prototype.toString.call(atob)
'function (){\n    console.log( "函数atob 被调用了 参数时",arguments)\n}'

  

他们用函数原型链上面的tostring 检测我们 那我们就连他一起给改了

我们发现这回是偷梁换柱 不被发现了

但是我们有没有想过 我们直接是修改的原型链上面的tostring    在其他函数调用同string时 如果自身属性里面没有同string 就会从原型链上面去找  

我们发现我们把代码给写死了 无论用什么函数调用同string方法 时都会返回

'function atob() { [native code] }'

接下来我们就调整代码我们不能写死 

this的意思是谁调用了这个tostring函数, this就指向谁 (那肯定是函数调用的tostring, 然后函数有一个name的属性 这个属性就是函数的名字)

本节内容讲解完毕 没有看明白的同学可以在评论区提出问题

  • 9
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值