// ==UserScript== // @name 移除广告内嵌脚本 // @namespace https://greasyfork.org/zh-CN/users/1373566 // @version 1.4.8 // @license MIT // @description 这是一个由AI生成的脚本,通过关键词匹配来移除网页中的内嵌广告脚本。不能保证100%成功,可以在脚本菜单中管理排除的网页和关键词。 // @author copilot & cheatgpt // @match http*://*/* // @exclude *://*.github.com/* // @exclude *://github.com/* // @exclude *://*.google.*/* // @exclude *://x.com/* // @exclude *://twitter.com/* // @exclude *://*.bing.*/* // @exclude *://*.yandex.*/* // @exclude *://*.iqiyi.com/* // @exclude *://*.qq.com/* // @exclude *://*.v.qq.com/* // @exclude *://*.sohu.com/* // @exclude *://*.mgtv.com/* // @exclude *://*.ifeng.com/* // @exclude *://*.pptv.com/* // @exclude *://*.sina.com.cn/* // @icon  // @grant GM_registerMenuCommand // @run-at document-start // @downloadURL none // ==/UserScript== (function() { 'use strict'; const REMOVE_AD_SCRIPTS_KEYWORDS_KEY = 'removeAdScriptsKeywords'; const EXCLUDE_SITES_KEY = 'excludeSites'; const DEFAULT_KEYWORDS = [ '.substr(10)', '.substr(22)', 'htmlAds', 'ads_codes', '{return void 0!==b[a]?b[a]:a}).join("")}', '-${scripts[randomIndex]}', '"https://"+Date.parse(new Date())+', '"https://"+(new Date().getDate())+', 'window.AdProvider', 'window.adbyunion', 'window.autoCopy', 'new Function(t)()', 'new Function(b)()', 'new Function(\'d\',e)', 'Math.floor(2147483648 * Math.random());', 'ClipboardJS', '¥ 666:/', 'disableDebugger', 'sojson.v', 'histats.com', 'pc.stgowan.com', 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789' ]; let keywords = getFromLocalStorage(REMOVE_AD_SCRIPTS_KEYWORDS_KEY, DEFAULT_KEYWORDS); let excludeList = getFromLocalStorage(EXCLUDE_SITES_KEY, []); let removedScriptsInfo = []; function getFromLocalStorage(key, defaultValue) { try { const item = localStorage.getItem(key); return item ? JSON.parse(item) : defaultValue; } catch (error) { console.error(`Error getting data from localStorage for key ${key}:`, error); return defaultValue; } } function saveToLocalStorage(key, value) { localStorage.setItem(key, JSON.stringify(value)); } function saveKeywords() { saveToLocalStorage(REMOVE_AD_SCRIPTS_KEYWORDS_KEY, keywords); } function saveExcludeList() { saveToLocalStorage(EXCLUDE_SITES_KEY, excludeList); } function removeSpecificScript() { if (excludeList.includes(window.location.hostname)) { console.log('Current site is excluded:', window.location.hostname); return; } document.querySelectorAll('script').forEach(script => { const matchedKeywords = keywords.filter(keyword => script.innerHTML.includes(keyword)); if (matchedKeywords.length > 0) { removedScriptsInfo.push({ keywords: matchedKeywords, content: script.innerHTML }); script.remove(); console.log('Removed script:', script); } }); } function addKeyword() { const newKeyword = prompt('请输入要添加的关键词:'); if (newKeyword) { keywords.push(newKeyword); saveKeywords(); alert('关键词已添加: ' + newKeyword); } } function showKeywords() { alert('当前关键词:\n' + keywords.join('\n')); } function showRemovedScriptsInfo() { if (removedScriptsInfo.length === 0) { alert('没有移除任何脚本。'); return; } let info = '移除的脚本信息:\n\n'; removedScriptsInfo.forEach((infoItem, index) => { info += `脚本 ${index + 1}:\n匹配关键词: ${infoItem.keywords.join(', ')}\n脚本内容:\n${infoItem.content}\n\n`; }); alert(info); } function manageSite(operation) { const currentSite = window.location.hostname; if (operation === 'exclude') { if (!excludeList.includes(currentSite)) { excludeList.push(currentSite); saveExcludeList(); alert('当前网址已排除: ' + currentSite); } else { alert('当前网址已在排除列表中'); } } else if (operation === 'add') { if (excludeList.includes(currentSite)) { excludeList = excludeList.filter(site => site !== currentSite); saveExcludeList(); alert('当前网址已从排除列表中移除: ' + currentSite); } else { alert('当前网址不在排除列表中'); } } } function createStyledElement(tagName, styles) { const element = document.createElement(tagName); Object.assign(element.style, styles); return element; } function editKeywords() { const overlay = createStyledElement('div', { position: 'fixed', top: '0', left: '0', width: '100%', height: '100%', backgroundColor: 'rgba(0,0,0,0.5)', zIndex: '9998' }); const editorContainer = createStyledElement('div', { position: 'fixed', top: '50%', left: '50%', transform: 'translate(-50%, -50%)', zIndex: '9999', width: '80vw', maxWidth: '600px', backgroundColor: '#f8f9fa', borderRadius: '8px', padding: '20px' }); const editor = createStyledElement('textarea', { width: '100%', height: '300px', backgroundColor: 'inherit', color: '#212529', border: '2px solid #4a90e2', borderRadius: '4px', padding: '15px', fontFamily: 'monospace', fontSize: '14px', boxSizing: 'border-box' }); editor.value = keywords.join('\n'); const buttonContainer = createStyledElement('div', { display: 'flex', gap: '10px', marginTop: '15px', justifyContent: 'flex-end' }); const buttonStyle = { padding: '8px 20px', color: 'white', border: 'none', borderRadius: '4px', cursor: 'pointer', fontSize: '14px' }; const saveButton = createStyledElement('button', { ...buttonStyle, backgroundColor: '#4CAF50' }); saveButton.textContent = '保存'; const resetButton = createStyledElement('button', { ...buttonStyle, backgroundColor: '#f44336' }); resetButton.textContent = '重置'; saveButton.onclick = () => { keywords = editor.value.split('\n') .map(k => k.trim()) .filter(k => k); saveToLocalStorage(REMOVE_AD_SCRIPTS_KEYWORDS_KEY, keywords); document.body.removeChild(overlay); document.body.removeChild(editorContainer); alert('关键词已更新'); }; resetButton.onclick = () => { if (confirm('确定重置为默认关键词?')) { keywords = [...DEFAULT_KEYWORDS]; editor.value = keywords.join('\n'); saveToLocalStorage(REMOVE_AD_SCRIPTS_KEYWORDS_KEY, keywords); alert('已恢复默认关键词'); } }; buttonContainer.append(saveButton, resetButton); editorContainer.append(editor, buttonContainer); document.body.append(overlay, editorContainer); } function showInlineScripts() { const scripts = document.querySelectorAll('script'); let scriptInfo = '网页中的内嵌脚本:\n\n'; scripts.forEach((script, index) => { if (script.innerHTML.trim()) { scriptInfo += `脚本 ${index + 1}:\n${script.innerHTML.trim()}\n\n`; } }); alert(scriptInfo); } const observer = new MutationObserver(mutations => { mutations.forEach(mutation => { if (mutation.addedNodes.length) { mutation.addedNodes.forEach(node => { if (node.tagName === 'SCRIPT') { removeSpecificScript(); } }); } }); }); observer.observe(document.documentElement, { childList: true, subtree: true }); removeSpecificScript(); GM_registerMenuCommand('排除当前网址', () => manageSite('exclude')); GM_registerMenuCommand('拦截当前网址', () => manageSite('add')); GM_registerMenuCommand('添加关键词', addKeyword); GM_registerMenuCommand('显示关键词', showKeywords); GM_registerMenuCommand('编辑关键词', editKeywords); GM_registerMenuCommand('移除脚本日志', showRemovedScriptsInfo); GM_registerMenuCommand('网页内嵌脚本查看', showInlineScripts); })();