可添加背景杂质和文字扭曲变形,效果如下:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Text Anti-OCR</title> <style> .anti-ocr-canvas { background-color: #f0f0f0; border: 1px solid #ccc; } </style> </head> <body> <canvas id="anti-ocr-canvas" width="400" height="100"></canvas> <script> function drawTextToCanvas(text, canvasId) { let canvas = document.getElementById(canvasId); let ctx = canvas.getContext('2d'); // 添加背景杂质 for (let i = 0; i < 1000; i++) { let x = Math.random() * canvas.width; let y = Math.random() * canvas.height; ctx.fillStyle = `rgba(14, 12, 123, ${Math.random() * 0.8})`; ctx.fillRect(x, y, 1, 1); } // 设置文字样式 ctx.font = '20px Arial'; ctx.fillStyle = '#333'; // 扭曲文字 let chars = text.split(''); let x = 10; let y = 50; for (let i = 0; i < chars.length; i++) { ctx.save(); ctx.translate(x, y); ctx.rotate(Math.random() * 0.7 - 0.1); ctx.fillText(chars[i], 0, 0); ctx.restore(); x += ctx.measureText(chars[i]).width + Math.random() * 4 - 2; } } drawTextToCanvas('这是一个防止OCR识别的文本。', 'anti-ocr-canvas'); </script> </body> </html>
网友回复
如何编写一个chrome插件实现多线程高速下载大文件?
cdn版本的vue在网页中出现typeerror错误无法找到错误代码位置怎么办?
pywebview能否使用webrtc远程控制共享桌面和摄像头?
pywebview6.0如何让窗体接受拖拽文件获取真实的文件路径?
如何在linux系统中同时能安装运行apk的安卓应用?
python有没有离线验证码识别ocr库?
各家的ai图生视频及文生视频的api价格谁最便宜?
openai、gemini、qwen3-vl、Doubao-Seed-1.6在ui截图视觉定位这款哪家更强更准?
如何在linux上创建一个沙箱隔离的目录让python使用?
pywebview如何使用浏览器自带语音识别与webspeech 的api?