function checkDevTools(options) { const isFF = ~navigator.userAgent.indexOf("Firefox"); let toTest = ''; if (isFF) { toTest = /./; toTest.toString = function() { options.opened(); } } else { toTest = new Image(); toTest.__defineGetter__('id', function() { options.opened(); }); } setInterval(function() { options.offed(); console.log(toTest); console.clear && console.clear(); }, 1000); } checkDevTools({ opened: function() { document.body.innerHTML = 'Dev Tools is on'; }, offed: function() { document.body.innerHTML = 'Dev Tools is off'; } });
通過此代碼可以監聽到是否打開開發者調試窗口。如果打開那么可以移除一些敏感信息,或者防爬蟲設定。
后續,又有一種兼容性較好的版本
setInterval(function() { check() }, 4000); var check = function() { function doCheck(a) { if (("" + a / a)["length"] !== 1 || a % 20 === 0) { (function() {} ["constructor"]("debugger")()) } else { (function() {} ["constructor"]("debugger")()) } doCheck(++a) } try { doCheck(0) } catch (err) {} }; check();
————————————————
版權聲明:本文為CSDN博主「SineyCoder」的原創文章,遵循 CC 4.0 BY-SA 版權協議,轉載請附上原文出處鏈接及本聲明。
原文鏈接:https://blog.csdn.net/a568283992/article/details/103022334