首页 > 文章列表 > 如何防止浏览器隐藏元素设置影响页面水印?

如何防止浏览器隐藏元素设置影响页面水印?

127 2024-11-14

如何防止浏览器隐藏元素设置影响页面水印?

阻止浏览器隐藏元素设置

在页面加入水印时,一个潜在的问题是浏览器提供的隐藏元素设置。为了防止用户通过该设置修改水印,可以采取以下措施:

1. 禁止右键菜单和 f12

以下代码可禁止右键查看源代码和使用 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)
    }
};

4. 转换为图片

将水印内容转换为图片可以有效防止用户隐藏或修改水印。这样做的好处是用户无法通过浏览器的隐藏元素设置来修改图像。

来源:1729909933