佬们,像这种 F12 一直调用 debugger 不让调试的网站有什么通用解开限制的解决办法吗?

45 天前
 timerring

网站 什么值得买: https://www.smzdm.com/

1104 次点击
所在节点    问与答
5 条回复
linauror
45 天前
一般切换到 source ,会自动定位到“debugger”代码的位置,右键添加到忽略列表,基本就可以了
hafuhafu
45 天前
直接工具栏里点停用断点 Ctrl+F8 ,然后继续...
覆盖源码也行。
timerring
45 天前
@linauror 还真是,感谢佬!
strugglers
45 天前
// ==UserScript==
// @name 移除开发者工具防护
// @namespace http://tampermonkey.net/
// @version 2025-04-02
// @description 移除页面中监听开发者工具打开的行为
// @author struggler
// @match *://*/*
// @icon 
// @grant none
// @run-at document-start
// ==/UserScript==

;(function () {
"use strict"

// 主防护函数
const applyProtections = () => {
// 1. 重写关键函数和构造函数
overrideFunctionConstructors()

// 2. 修改定时器行为
modifyTimers()

// 3. 处理 eval 和错误捕获
handleEvalAndErrors()

// 4. 反开发者工具检测
antiDevToolsDetection()

// 5. 移除事件监听
//removeEventListeners()

// 6. 覆盖常见检测函数
overrideDetectionFunctions()

// 7. 阻止 debugger 检测
preventDebuggerDetection()

console.log("[开发者工具防护] 所有防护措施已激活")
}

// 1. 重写关键函数和构造函数
const overrideFunctionConstructors = () => {
// 重写 Function 构造函数
Function.prototype.constructor_ = Function.prototype.constructor
Function.prototype.constructor = function (code) {
if (code === "debugger") {
return function () {}
}
return Function.prototype.constructor_.call(this, code)
}
}

// 2. 修改定时器行为
const modifyTimers = () => {
// 重写 setInterval 函数
const originalSetInterval = window.setInterval
window.setInterval = function (callback, delay) {
if (callback && callback.toString) {
var funString = callback.toString()
if (funString.indexOf("debugger") > -1) return
if (funString.indexOf("window.close") > -1) return
}
delay = delay * 10000
return originalSetInterval(callback, delay)
}
}

// 3. 处理 eval 和错误捕获
const handleEvalAndErrors = () => {
// 保存原始的 try-catch 逻辑
const originalTryCatch = {
try: window.eval,
catch: window.onerror,
}

// 劫持 eval
window.eval = function (code) {
return originalTryCatch.try.apply(this, arguments)
}

// 劫持全局错误处理
window.onerror = function () {
return true
}
}

// 4. 反开发者工具检测
const antiDevToolsDetection = () => {
// 禁用基于 debugger 的检测
window.debugger = function () {}
window.debugger.toString = () => "function debugger() { [native code] }"
window.console.clear = () => {}

// 禁用基于 console.log 的检测
if (!window.console) window.console = {}

// 禁用基于时间差的检测
const originalDate = window.Date
window.Date = new Proxy(window.Date, {
construct(target, args) {
if (args.length === 0) {
return new originalDate(originalDate.now())
}
return new originalDate(...args)
},
})

// 禁用基于 Function.toString 的检测
const originalToString = Function.prototype.toString
Function.prototype.toString = function () {
if (this === window.console.log || this === window.debugger) {
return "function() { [native code] }"
}
return originalToString.call(this)
}

// 禁用基于窗口大小的检测
Object.defineProperty(window, "outerWidth", {
get: () => window.innerWidth + 100,
configurable: false,
})
Object.defineProperty(window, "outerHeight", {
get: () => window.innerHeight + 100,
configurable: false,
})
}

// 5. 移除事件监听
const removeEventListeners = () => {
// 覆盖 addEventListener
const originalAdd = EventTarget.prototype.addEventListener
EventTarget.prototype.addEventListener = function (type) {
if (["keydown", "resize"].includes(type)) {
return
}
originalAdd.apply(this, arguments)
}

// 清除特定事件属性
;["onkeydown", "onresize"].forEach((prop) => {
if (window[prop]) window[prop] = null
if (document[prop]) document[prop] = null
})
}

// 6. 覆盖常见检测函数
const overrideDetectionFunctions = () => {
window.__detectDevTools = function () {
return false
}
window.__CHROME_DEVTOOLS_EXTENSION_DETECTED__ = false
window.devtools = { isOpen: false }
window.performance.now = function () {
return Date.now()
}
}

// 7. 阻止 debugger 检测
const preventDebuggerDetection = () => {
const originalDebugger = Function.prototype.constructor
Function.prototype.constructor = function () {
const fn = originalDebugger.apply(this, arguments)
if (arguments[0] && arguments[0].includes("debugger")) {
return function () {}
}
return fn
}
}

// 立即执行所有防护措施
applyProtections()
})()


写了个油猴脚本解决
Sdyhgc
45 天前
16 进制修改 debugger 字符串 替换成其他的,一劳永逸

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://ex.noerr.eu.org/t/1136084

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX