测试地址https://tongcheng360.com/
堆栈回溯可以拿到
A = window.setInterval(function() {
if (!(e.isSuspend || l || D())) {
var t, n, i = f(U);
try {
for (i.s(); !(t = i.n()).done; ) {
var o = t.value;
L[o.type] = !1,
o.detect(q++)
}
} catch (e) {
i.e(e)
} finally {
i.f()
}
T(),
"function" == typeof d.ondevtoolclose && (n = j,
!_() && n && d.ondevtoolclose())
}
}, d.interval),
根据代码特征很像这个库
https://link.zhihu.com/?target=https%3A//github.com/theajack/disable-devtool
data:image/s3,"s3://crabby-images/5dad2/5dad2be20636178913908e27a5ed7d0d2fea17da" alt="v2-8f53658cb56c9ba04d23363862934c13_720w.webp"
先不思考太多,我们先一处一处过,首先对setInterval进行hook,对函数进行toString来检测
代码如下
// ==UserScript==
// @name Pass Console
// @namespace https://bbs.tampermonkey.net.cn/
// @version 0.1.0
// @description try to take over the world!
// @author You
// @match https://tongcheng360.com/*
// @run-at document-start
// @grant none
// ==/UserScript==
const originSetInterval = window.setInterval
window.setInterval = function (func, time) {
if (func.toString().indexOf('ondevtoolclose') !== -1) {
return -1
}
return originSetInterval.call(this, func, time)
}
测试一下,结果发现只有这一个地方检测
data:image/s3,"s3://crabby-images/cd7ac/cd7ac849f56ab1ddc6fbe3ab7f89bfbd90aad608" alt="v2-4c7401258b74e7cf87273067c58ce9e2_720w.webp"
除此以外也可以直接打死初始化点
Object.defineProperty(window, "DisableDevtool", {
get: function () {
return function(){
}
},
set: function (str) {
},
});