目标网址:http://zrzy.gansu.gov.cn/zrzy/c116319/xxgk_list.shtml
首先 如果对Debugger不了解的同学 参考我上一期博客 下面我们直接进入实战
浏览器输入网址回车后 F12
此时就会发现 页面已经被Debugger断住
对代码格式化后 会得到以下页面
data:image/s3,"s3://crabby-images/7d9cc/7d9cc9509056d0e377898169a2cae66a8e3146e6" alt=""
这里不难发现 除了第2706行的debugger断点外 页面还用了如变量名混淆一类的js混淆技术
暂时看不出这里的代码有什么端倪
data:image/s3,"s3://crabby-images/27235/272350000fd09038fb061fd3859a2067befcd45e" alt=""
先直接用上一期讲的Edit breakpoint方法跳过这个debugger
data:image/s3,"s3://crabby-images/27959/279594bc20b8b2b019c7286dafbaf2fd521070c4" alt=""
将debugger属性改为false
data:image/s3,"s3://crabby-images/04c4c/04c4ccce2fff00f7ed30bb41edbb7b00deaa29af" alt=""
直接下一步
data:image/s3,"s3://crabby-images/4f48b/4f48b036536cdd3a634a9ba0544705b02392a55b" alt=""
此时会发现 已经陷入了新的虚拟机断点中 并且这里对时间进行了检测
不难想象 如果我们处理不当 会直接陷入无限debugger
这里如果只对debugger进行处理 显然是没有用的 因为我们无法控制两个时间戳相减小于100
所以最直接的想法便是修改调用处的代码
data:image/s3,"s3://crabby-images/d82e4/d82e48c85e04409aab8152b60226a60d81de898a" alt=""
我们对他进行跟栈 可以找到如上调用处
此时我们已经回到了VM7中 我们对调用处进行具体分析
data:image/s3,"s3://crabby-images/f4313/f4313cc48a7f344b3fc80b2915f916c2f5a4a581" alt=""
data:image/s3,"s3://crabby-images/3b177/3b1770a451b72bbb4a513cdb0131915d36578f56" alt=""
data:image/s3,"s3://crabby-images/fb841/fb8419f3f6dbfbadcebebd8e073162f20bd4aa58" alt=""
data:image/s3,"s3://crabby-images/b987a/b987a507b2941124a2ae8f446228905841f99dff" alt=""
综合以上信息 我们可以得出以下结论
// _$de == Window
// _$dh == "eval"
// _$ek == Array()
// _$bY == 2
// _$ek[2] == "(function() {var a = new Date(); debugger; return new Date() - a > 100;}())"
// 所以 这一行实际代码如下
eval("(function() {var a = new Date(); debugger; return new Date() - a > 100;}())")
此时我们已经分析出 陷入debugger的真正起因
解决起来也就非常容易了 我们直接使用代码替换的方式 将_$ek[2]中debugger替换掉
_$ek[2] = _$ek[2].replace("debugger;"," ");
在控制台执行以上代码
这里需要注意 首先你的数组名与我的不一定一样 需要根据实际情况写数组名
第二养成好习惯 替换时让字符串长度不变 防止对方对字符串长度进行检测
data:image/s3,"s3://crabby-images/04251/04251046c7f50fe6bed52a029bf5672bc7803c0f" alt=""
同时我们回到VM78中 将此处的debugger跳过
data:image/s3,"s3://crabby-images/86c77/86c7709eeeee2ad01d95fbf92163e629ef0e6795" alt=""
再次点击小箭头
此时可以发现 我们已经成功绕过了所有debugger反爬
网友评论