如何防止用户滥用浏览器隐藏元素设置
水印在网页安全中至关重要,但用户可以通过浏览器的“隐藏元素”选项轻松绕过这种保护措施。本文将探讨如何在浏览器中禁止隐藏元素,以及隐藏元素可能引发的事件和样式修改。
禁用隐藏元素的解决方案
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 特性的无限递归
该方法可以阻止用户浏览代码,但不能检测控制台是否打开:
function check() { function doCheck(a) { (function() {}["constructor"]("debugger")()); //debugger doCheck(++a); } try { doCheck(0) } catch(err) { console.log(err) }}
登录后复制
4. 将水印转换为图片
将水印转换为图片可以防止用户单独将其删除。
以上就是如何防止用户通过浏览器“隐藏元素”选项绕过网页水印保护?的详细内容,更多请关注【创想鸟】其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。
发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2661689.html