禁止浏览器隐藏元素设置防止用户篡改网页时,如何应对控制台调试带来的隐患?

禁止浏览器隐藏元素设置防止用户篡改网页时,如何应对控制台调试带来的隐患?

禁止浏览器隐藏元素设置

防止用户篡改网页时,浏览器隐藏元素功能可能成为隐患。如何应对这一挑战?

解决方案

首先,可以通过禁止打开控制台,防止用户进行代码调试:

方案 1

禁止右键查看源码和 F12:

// 禁止 F12 键盘事件document.addEventListener('keydown', function(event){  return 123 != event.keyCode || (event.returnValue = false)});// 禁止右键、选择、复制document.addEventListener(‘'contextmenu'’, function(event){  return event.returnValue = false})

登录后复制

方案 2

通过页面宽度变化监测控制台:

监测可视区域宽高和浏览器宽高的差值,如果超过设定的阈值,则判断控制台已打开。

function resize(){  var threshold = 200;  var widthThreshold = window.outerWidth - window.innerWidth > threshold;  var heightThreshold = window.outerHeight - window.innerHeight > threshold;  if(widthThreshold || heightThreshold){    console.log('控制台打开了')  }}window.addEventListener('resize', resize);resize()

登录后复制

方案 3

利用 debugger 特性,无限递归:

如果没有调试功能可用,debugger 语句将不起作用。利用这个特性,可以阻止代码执行:

function check() {  function doCheck(a) {    (function() {}["constructor"]("debugger")()); //debugger    doCheck(++a);  }  try {    doCheck(0)  } catch(err) {    console.log(err)  }};

登录后复制

最后,将网页整体转换成图片也是一种选择,用户无法单独去除。

以上就是禁止浏览器隐藏元素设置防止用户篡改网页时,如何应对控制台调试带来的隐患?的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2801946.html

(0)
上一篇 2025年3月8日 21:23:07
下一篇 2025年3月8日 21:23:13

AD推荐 黄金广告位招租... 更多推荐

相关推荐

发表回复

登录后才能评论