您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
使用ddddocr识别验证码并回填
// ==UserScript== // @name 验证码识别并回填 // @namespace http://tampermonkey.net/ // @license MIT // @version 2025-08-22 // @description 使用ddddocr识别验证码并回填 // @author hukss // @match https://mall.recycloud.cn/ // @icon  // @grant GM_xmlhttpRequest // ==/UserScript== (function() { /* 等待 JS 把真正的 base64 验证码写进 <img> */ function waitForRealBase64Img(selector) { return new Promise((resolve) => { const check = () => { const img = document.querySelector(selector); if (img && img.src.startsWith('data:image/')) { resolve(img); } else { requestAnimationFrame(check); // 每帧检查一次 } }; check(); }); } /* ========= 主流程 ========= */ (async () => { /* ------------ 创建按钮 ------------ */ function addButton() { if (document.getElementById('gm-captcha-btn')) return; // 已存在 const btn = document.createElement('button'); btn.id = 'gm-captcha-btn'; btn.textContent = '识别验证码'; Object.assign(btn.style, { position: 'fixed', top: '10px', right: '10px', zIndex: 9999, padding: '6px 12px', background: '#409eff', color: '#fff', border: 'none', borderRadius: '4px', cursor: 'pointer', fontSize: '12px' }); document.body.appendChild(btn); btn.addEventListener('click', handleCaptcha); } /* ------------ 启动 ------------ */ // 等 DOM 就绪后再加按钮 if (document.readyState === 'loading') { document.addEventListener('DOMContentLoaded', addButton); } else { addButton(); } /* ------------ 识别逻辑 ------------ */ /* ------接口代码地址---https://github.com/gdlden/ddddocrDemo--- */ function handleCaptcha() { const img = document.querySelector('.imgCode'); if (!img || !img.src.startsWith('data:image/')) { alert('验证码图片尚未加载完成,请稍后再试'); return; } const base64 = img.src; GM_xmlhttpRequest({ method: 'POST', url: 'http://localhost/randomData/getImageCode', headers: { 'Content-Type': 'application/json' }, data: JSON.stringify({ base64Image: base64 }), responseType: 'json', onload: (resp) => { const result = resp.response; if (result && result.data) { const code = result.data.trim(); const inputEl = document.querySelector('input[placeholder*="图形验证码"]'); if (inputEl) { inputEl.value = code; inputEl.dispatchEvent(new Event('input', { bubbles: true })); } } else { alert('识别接口返回异常'); } }, onerror: () => alert('识别接口调用失败') }); } })(); })();