前端实现网页水印防移除的实战方案_javascript技巧

核心痛点:纯前端水印无法绝对防破解,但可通过组合技术大幅增加破解成本!

// 创建动态水印层(混淆选择器+随机位置)const createWatermark = () => { const wm = document.createElement('div'); // 随机生成类名(规避通配选择器) const randomId = 'wm_' + Math.random().toString(36).slice(2, 8); wm.className = randomId; // 水印内容(含用户信息) wm.innerHTML = `© ${user.name} · ${new Date().toLocaleDateString()}`; // 随机位置偏移(破坏自动化脚本) wm.style.left = `${Math.random() * 20}%`; wm.style.top = `${Math.random() * 15}vh`; // 核心样式 Object.assign(wm.style, { position: 'fixed', pointerEvents: 'none', opacity: '0.5', transform: `rotate(${Math.random() * 15 - 7.5}deg)`, zIndex: '2147483647' // 最大z-index值 }); document.body.appendChild(wm); return wm;};

防护原理

// MutationObServer监听水印移除const initWatermarkGuard = () => { const wm = createWatermark(); const observer = new MutationObserver((mutations) => { let watermarkRemoved = false; mutations.forEach(mutation => { if (mutation.removedNodes) { Array.from(mutation.removedNodes).forEach(node => { if (node === wm || node.contains?.(wm)) { watermarkRemoved = true; } }); } }); if (watermarkRemoved) { console.warn("水印被移除,正在重生..."); document.body.removeEventListener('DOMNodeRemoved', handleRemove); observer.disconnect(); createWatermark(); initWatermarkGuard(); // 重新绑定监听 } }); // 深度监听整个body observer.observe(document.body, { childList: true, subtree: true, attributes: false, characterData: false }); // 备份监听:处理iframe等特殊情况 const handleRemove = (e) => { if (e.target === wm) { document.body.appendChild(wm.cloneNode(true)); } }; document.body.addEventListener('DOMNodeRemoved', handleRemove);};

防护原理

// Canvas内容融合水印(关键数据防篡改)const drawProtectedCanvas = (canvas) => { const ctx = canvas.getContext('2d'); const img = new Image(); img.onload = () => { ctx.drawImage(img, 0, 0); // 半透明水印覆盖 ctx.fillStyle = 'rgba(255,255,255,0.5)'; ctx.font = 'bold 24px sans-serif'; ctx.fillText('@' + user.id, canvas.width/2, canvas.height-30); // 隐形水印(像素级操作) const imageData = ctx.getImageData(0, 0, canvas.width, canvas.height); encodeWatermark(imageData.data, user.id); // 自定义编码函数 ctx.putImageData(imageData, 0, 0); }; img.src = '/sensitive-image.jpg';};// 隐形水印编码function encodeWatermark(pixels, userId) { // LSB最低有效位隐写术 for (let i = 0; i < pixels.length; i += 4) { if (i % 16 === 0) { const charCode = userId.charCodeAt(Math.floor(i/16) % userId.length); const bit = (charCode >> Math.floor(i/16)%8) & 1; pixels[i] = (pixels[i] & 0xFE) | bit; } }}

防护原理

// DevTools开启检测(现代浏览器适配)setInterval(() => { const devtools = { open: false, orientation: null }; const threshold = 160; // 屏幕高度阈值 const widthThreshold = window.outerWidth - window.innerWidth > threshold; const heightThreshold = window.outerHeight - window.innerHeight > threshold; const orientation = widthThreshold ? 'vertical' : 'horizontal'; if ( !devtools.open && (heightThreshold || widthThreshold) && devtools.orientation !== orientation ) { devtools.open = true; devtools.orientation = orientation; // 开发者工具打开时自动刷新 window.location.reload(); }}, 1000);

防护原理

// 基于SVG的矢量水印(PDF导出保留)const svgWM = ` ${user.name} ${new Date().toISOString()} `;const svgURL = `data:image/svg+xml,${encodeURIComponent(svgWM)}`;document.body.style.backgroundImage = `url("${svgURL}")`;

// WebGL着色器注入水印(逐帧渲染)const fragmentShader = ` varying vec2 vUv; uniform sampler2D videoTexture; void main() { vec4 color = texture2D(videoTexture, vUv); vec2 center = vec2(0.5, 0.85); float dist = distance(vUv, center); if (dist < 0.2) { color.rgb = mix(color.rgb, vec3(1.0), 0.5); color.r = mod(color.r + 0.5, 1.0); // 添加颜色偏移 } gl_FragColor = color; }`;

// 敏感操作时强化水印function protectSensitiveAction() { createWatermark(); document.body.classList.add('watermark-intensify'); setTimeout(() => document.body.classList.remove('watermark-intensify'), 5000 );}

服务端协同验证

// 关键接口添加数字水印fetch('/api/export', { headers: { 'X-Content-Signature': btoa(`${user.id}|${window.location.host}|${Date.now()}`) }})

环境自销毁机制

// 检测常见破解环境特征const isTampered = window.__watermarkGuard !== true || navigator.webdriver === true;if (isTampered) { document.body.innerHTML = '

安全警告:非法环境访问

'; window.stop();}

// 水印渲染性能优化requestAnimationFrame(() => { const wm = createWatermark(); setTimeout(() => wm.style.transition = 'opacity 0.3s', 100);});

用户体验保障

到此这篇关于前端实现网页水印防移除的实战方案的文章就介绍到这了,更多相关前端网页水印防移除内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!


本文地址: https://www.earthnavs.com/jishuwz/df6d9db282c74595cc10.html
全局中部横幅
小刀娱乐网

爱网络,爱这里。网络人的烟火,熬不尽的网络江湖。专注活动,软件,教程分享!总之就是网络那些事。

The
The

Knowwhichwayisup.Trusteddailyreportingandnewsanalysis.Makesenseofpolitics,economics,businessandtechnologywitharticles,podcastsandvideos.

联想

联想_lenovo笔记本电脑_平板电脑_手机_台式机_服务器_外设数码_联想官网

腾讯网

腾讯网从2003年创立至今,已经成为集新闻信息,区域垂直生活服务、社会化媒体资讯和产品为一体的互联网媒体平台。腾讯网下设新闻、科技、财经、娱乐、体育、汽车、时尚等多个频道,充分满足用户对不同类型资讯的需求。同时专注不同领域内容,打造精品栏目,并顺应技术发展趋势,推出网络直播等创新形式,改变了用户获取资讯的方式和习惯。

湖南在线

湖南在线是由湖南日报社主办的地方重点新闻门户网站,提供新闻信息、生活资讯、客户端、微博、活动策划、舆情、广告等服务,以传统报纸媒体为依托,创建了新湖南客户端,以新兴产业为一体的新型融媒体信息服务商、文化产业综合服务提供商。

闪库

闪库是一款免费的端口映射及内网穿透软件,使您无需服务器,无需公网IP,无需设置路由器即可对外发布应用,远程桌面,支付调试,NAS云盘,游戏联机等都可使用,支持Http,Https,Tcp,Udp协议.

URLOS

基于容器技术的新一代主机管理系统,将网站、小程序和APP等应用运行在多台主机上,弹性加减硬件,单机故障不影响在线业务。

SugarHosts

Sugarhosts以超值的价格提供品质卓越的美国、欧洲、亚洲主机服务,同时提供一百种域名与数十种SSL安全证书

阿里邮箱

阿里邮箱是业内唯一基于云计算原生公有云服务的邮件运营商,阿里企业邮箱为企业用户提供高安全、高性能、高稳定的邮件企业服务,海外多点部署,全球畅邮

分类目录

建链网分类目录,为广大草根站长提供最专业的网站快审服务,永久收录网站导航,开放式网站分类目录平台,网站目录免费收国内外各行业优秀网站,永久收录和永久锚文本让您的网站在各大搜索引擎收录快、排名靠前的高权重综合性网站目录平台。