码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Js逆向教程-14反调试


    Js逆向教程-14反调试

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-JjDGSrtN-1669452128125)(1.png)]

    一、检测是否在调试

    1. 键盘监听(F12)
    2. 检测浏览器的高度插值
    3. 检测开发者人员工具变量是否为true
    4. 利用console.log调用次数
    5. 利用代码运行的时间差
    6. 利用toString
    7. 检测非浏览器

    二、显性

    2.1 debugger:
    function xx() {
        debugger;
        console.log(1);
    }
    
    function xuhss() {
        xx();
    }
    xuhss() 
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-T4Q2ybHt-1669452128126)(02 - 副本.assets/image-20221126152022935.png)]

    代码会在调试的时候段下来

    跳过Debugger的方式
    2.1.1非虚拟机

    非虚拟机的方式不会跳转 到一个vm的页面

    方式一:

    通过将editbreakpoint设置为false 可以禁用这个调试

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-jiotPAeA-1669452128127)(编辑断点.gif)]

    方式二:

    跳过代码

    利用chrome插件

    • Fiddler(代理替换)
    • 油猴插件(需要自己写代码 )
    2.1.2虚拟机(eval() Function())

    在eval里面运行debugger.

    var aaa =Function.prototype.constructor("debugger;")
    
    • 1

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-7T5Um8gc-1669452128127)(xunijidubugger.gif)]

    通过hook方式,将运行的函数设为空就可以跳过debugger了

    Function.prototype.constructor = function(){}
    
    • 1

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-86cCPHSn-1669452128128)(xunijidubugger2.gif)]

    2.2 死循环
    1. 循环语句
    2. 无限递归
    3. 两个方法互相调用
    4. 计时器

    ( 打开页面 写历史记录卡死)

    三、隐形(暗装)

    发现你调试之后 引入错误的逻辑。

    将你的预期值和实际值进行比较,如果不一样,就是这种debugger 只能通过浏览器调用的堆栈区分出正确的逻辑

    最好的方式就是不要被识别出来调试,可以通过下hook解决。

  • 相关阅读:
    达梦数据库常用SQL之生成启用自增列表插入功能及insert插入语句
    10_12C++
    C语言--求一个 3 X 3 的整型矩阵对角线元素之和
    深入体验Java Web开发内目-核心基础 PDF篇
    卷积神经网络
    【考研数据结构代码题6】构建二叉树及四大遍历(先中后层)
    反序列化漏洞复现(typecho)
    kafka-eagle部署
    c语言分层理解(c语言字符串+内存库函数)
    C语言学习书籍 零基础入门篇
  • 原文地址:https://blog.csdn.net/huangbangqing12/article/details/128053805
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号