网页调试之debugger原理与绕过

简介: 当我们调试JS的时候,时常会遇见无限debugger。无限debugger的原理是什么呢?它在何时触发?如何绕过?

当我们调试JS的时候,时常会遇见无限debugger。无限debugger的原理是什么呢?它在何时触发?如何绕过?


debugger 语句用于停止执行 JavaScript(以下简称JS),并调用 (如果可用) 调试函数。

使用 debugger 语句类似于在代码中设置断点。


注意:如果调试工具不可用,则调试语句将无法工作。


实现debugger功能


直接使用书写debugger


<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <title>Example DEBUGGER</title>
</head>
<body>
    <script>
        debugger;
    </script>
</body>
</html>


当我们使用浏览器打开Devtools即执行debugger;如下图所示


eval配合debugger


eval() 函数计算 JavaScript 字符串,并把它作为脚本代码来执行。


如果参数是一个表达式,eval() 函数将执行表达式。如果参数是Javascript语句,eval()将执行 Javascript 语句。


<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <title>Example DEBUGGER</title>
</head>
<body>
    <script>
        var a = 1;
        eval("var 1 = 1;debugger")
    </script>
</body>
</html>


当使用eval执行时,将会在虚拟机中执行,也就是说非同一作用域。


同时也由于将字符串当作表达式来执行,那么里面常常伴随着代码混淆


函数内执行debugger


<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <title>Example DEBUGGER</title>
</head>
<body>
    <script>
        (function a(){
            var data = Date();
            alert(data);
            debugger;
        }())
    </script>
</body>
</html>


因为以上三种体现形式,在debugger上所设计的方案十分多。例如常见的无限制debugger、配合settimeout延迟debugger、代码混淆+debugger等等。


设置debugger的原理去对抗反爬,其核心原理就是如果调试工具可用,则调试语句将执行.也就是经常一打开就跳出debugger。


无限debugger,其实是一种泛指的概念,无限泛指多,而非真的无限

其基于debugger之上,在此加入多次执行debugger的语句从而实现“无限debugger”。“反正只要chrome Devtools不开debugger便不会执行”.(经过调试是这样的,如果不准确请自行完善哦)


debugger绕过原理


debugger的绕过也很简单,我个人总结共有两种大的方向。它们分别是替换、掠过。其原理都是不让debugger执行。个人并不推荐新手使用替换法中的方法


  • 替换法


  • JS注入


  • 重写(Hook)


  • 掠过法


  • Never pause here


  • 条件断点


JS注入


实现js注入的方式有很多,例如chrome Devtools的overrides、fiddler autoresponse、 mitmproxy、Charles的map local等等。若有兴趣自行搜索其使用方式


Never pause here

image.gif

找到debugger前面的行号,鼠标右键点击该行号,点击Never pause here。便会跳过此断点


条件断点


640.jpg

640 (1).jpg


找到debugger前面的行号,鼠标右键点击该行号,点击 Add conditional breakpoint,直接写false。回车即可


Deactivate breakpoints


640 (2).jpg


打开这个图标如下图所示(高亮为打开)


640 (3).jpg


当遇见breakpoints时会执行一次断点,鼠标单击如下图标


640 (4).jpg


即可直接跳过breakpoints。


小技巧:Deactivate breakpoints可以配合xhr、dom、Script等断点使用,便于调试


Hook绕过


function a() {
    eval("debugger");
}


(function() {
    var eval_cache = eval;
    eval = function(obj) {
        if (obj.indexof('debugger') === -1) {
            eval_cache(obj);
        }
    }
}())


此方法有局限性,若在此函数(在这里指函数a)若没有借用相关函数(eval),那么就无法使用此方法绕过


函数滞空法


当遇见断点时,回退一次堆栈。将对应函数滞空即可,例如遇见如下的debugger


function a() {
  debugger;
    eval("debugger");
}


直接在控制台输入如下内容即可。


640 (5).jpg


此方法有局限性,若在此函数中还参杂了关键代码,将可能无法访问或调试等


总结


Debugger绕过其实并不难,但在调试中仅仅是一道“开胃菜”,本节总结了debugger的实现方式,以及触发机制。当然也总结了几种我已知的所有绕过方案。


展望


如何hook“变量”debugger?如果可以实现那么就可以实现反调试的debugger“通杀”,当然目前我也有在探究此方案。在加到hook函数中,那么调试便可以近似于一步到位。

目录
相关文章
|
Web App开发 JavaScript 前端开发
Python 自动化 - 浏览器chrome打开F12开发者工具自动Paused in debugger调试导致无法查看网站资源问题原因及解决方法,javascript反调试问题处理实例演示
Python 自动化 - 浏览器chrome打开F12开发者工具自动Paused in debugger调试导致无法查看网站资源问题原因及解决方法,javascript反调试问题处理实例演示
758 0
|
3月前
|
数据采集 JavaScript 前端开发
JavaScript逆向爬虫——无限debugger的原理与绕过
JavaScript逆向爬虫——无限debugger的原理与绕过
158 2
|
5月前
|
存储 JSON 监控
JavaScript 逆向基础篇:浏览器调试与 Hook 技术
JavaScript 逆向基础篇:浏览器调试与 Hook 技术
473 1
|
6月前
|
Web App开发 前端开发 JavaScript
前端必备的浏览器调试技巧
【7月更文挑战第18天】 Chrome开发者工具是前端调试的关键,包括快捷键Ctrl+Shift+I/Cmd+Option+I打开它,DOM和CSS调试如编辑元素、样式,JS调试如断点、条件断点和监视变量,网络请求分析,性能评估如Lighthouse和性能面板,及截图、模拟设备等实用技巧,助力开发者提升效率。
160 1
|
8月前
|
监控 前端开发 JavaScript
如何使用浏览器调试前端代码?
【4月更文挑战第11天】前端开发中,浏览器调试是关键技能,能提升代码质量。本文介绍了如何使用浏览器的调试工具:1) 打开调试窗口(F12或右键检查);2) Elements标签页检查DOM结构和样式;3) Console调试JavaScript,查看日志和错误信息;4) Sources设置断点调试JS文件;5) 利用Network、Performance和Memory等标签页优化性能。熟悉调试工具、利用日志和错误信息能有效定位问题,提高开发效率。
430 7
|
安全 前端开发 Java
IE浏览器的静默打印与踩坑
IE浏览器的静默打印与踩坑
204 0
|
Web App开发 前端开发 JavaScript
炫酷浏览器调试小技巧,别跟我说你全知道?
炫酷浏览器调试小技巧,别跟我说你全知道?
|
Web App开发 JavaScript 前端开发
前端浏览器高级调试技巧整理
前端浏览器高级调试技巧整理
|
iOS开发 开发者
配合LLDB调试器进行iOS代码调试(一)
配合LLDB调试器进行iOS代码调试
200 0
配合LLDB调试器进行iOS代码调试(一)
window.open被浏览器拦截终极解决方案
window.open被浏览器拦截终极解决方案
236 0