当前位置: 首页 > news >正文

【前端】禁止别人调试自己的前端页面代码

  1. 无限debugger
  • 前端页面防止调试的方法主要是通过不断 debugger 来疯狂输出断点,因为 debugger 在控制台被打开的时候就会执行
  • 由于程序被 debugger 阻止,所以无法进行断点调试,所以网页的请求也是看不到的
  • 代码如下:

/**
* 基础禁止调试代码
*/
(() => {
 function ban() {
   setInterval(() => {
     debugger;
   }, 50);
 }
 try {
   ban();
 } catch (err) { }
})();

2. 无限debugger对策

2.1 可以通过控制台中的按钮或者使用快捷键 Ctrl + F8 关闭无限 debugger

*注意:这种方式虽然能去掉碍眼的 debugger,但是无法通过左侧的行号添加 breakpoint

2.2 添加 logpoint 为 false

选择对应的代码行,通过添加logpoint为 false,然后按回车

2.3 添加忽略执行代码行或文件

找到对应的代码行右键‘向忽略列表添加脚本’

3. 对 logpoint 为 false 的对策

将debugger代码写成一行,此时就算是使用代码格式化也无用

  1. 对忽略执行的对策

可以将 debugger 改写成 Function("debugger")();

Function 构造器生成的 debugger 会在每一次执行时开启一个临时 js 文件

5. 监听控制台打开修改页面内容

<script>
  (() => {
    function block() {
      if (window.outerHeight - window.innerHeight > 200 || window.outerWidth - window.innerWidth > 200) {
        document.body.innerHTML = "检测到非法调试,请关闭后刷新重试!";
      }
      setInterval(() => {
        (function () {
            return false;
          }
          ['constructor']('debugger')['call']());
      }, 50);
    }
    try {
      block();
    } catch (err) {}
  })();
</script>

6.其他防调试技术
6.1. 禁止右键菜单

document.oncontextmenu = function () {
    return false;
};
document.oncontextmenu = new Function("event.returnValue=false");

6.2. 禁止F12快捷键

// 禁止 F12 快捷键
document.onkeydown = document.onkeyup = document.onkeypress = function () {if (window.event.keyCode == 123) {
        window.event.returnValue = false;}
}
document.onkeydown = () => {//禁用F12if (window.event && window.event.keyCode == 123) {return false;//禁用ctrl+shift+i,} else if (window.event.ctrlKey && window.event.shiftKey && window.event.keyCode == 73) {return false;//屏蔽Shift+F10} else if (window.event.shiftKey && window.event.keyCode == 121) {return false;}
};

http://www.lryc.cn/news/163354.html

相关文章:

  • UDP的可靠性传输
  • 科研笔记:TPAMI submission guideline
  • Python文件操作(02):打开文件、读文件、关闭文件
  • C语言访问Mysql
  • 软件设计师(十)网络与信息安全基础知识
  • 蓝桥杯官网填空题(换零钞)
  • JavaFX之Stage
  • 深度翻页导出导致慢SQL,mysqlCPU飙升优化方案
  • 小谈设计模式(1)—总序
  • 【c++】stringstream基础:实现数据类型转换和字符串分割
  • Java基础学习笔记-5
  • 合同交付类项目如何高效管理?
  • 两性养生网站源码 生活类减肥网站源码 健康网模板源码 支持QQ登录和百度主动推送
  • CentOS7安装Jenkins(更改默认运行的端口号8080->16060)
  • Java开发之Mysql【面试篇 完结版】
  • 【实战】十二、自动化测试 —— React17+React Hook+TS4 最佳实践,仿 Jira 企业级项目(二十九)
  • 【人月神话】重新探索人月神话:软件工程的现实与挑战
  • 电阻和电容
  • 01-Java-日志框架
  • 【js】map、filter、reduce、fill(待补充...)
  • 【JPC出版】第二届能源与电力系统国际学术会议 (ICEEPS 2023)
  • 51单片机的简易篮球计分器倒计时仿真设计( proteus仿真+程序+原理图+报告+讲解视频)
  • 医院安全不良事件报告系统源码 PHP+ vue2+element+ laravel8+ mysql5.7+ vscode开发
  • Mybatis -- 读取 DATE 类型字段时可能遇到的问题(夏令时问题)
  • 第10节-PhotoShop基础课程-选区工具
  • 【C++】C++动态内存管理
  • Java中使用JTS实现WKT字符串读取转换线、查找LineString的list中距离最近的线、LineString做缓冲区扩展并计算点在缓冲区内的方位角
  • 【异步VS多线程】异步VS多线程区别
  • 【nosql】redis之高可用(主从复制、哨兵、集群)搭建
  • js如何实现数组去重的常用方法