NOTICE: By continued use of this site you understand and agree to the binding Terms of Service and Privacy Policy.
// ==UserScript== // @name 移除广告内嵌脚本 // @namespace https://greasyfork.org/zh-CN/users/1373566 // @version 1.4.9.4 // @license MIT // @description 这是一个由AI生成的脚本,通过关键词匹配来移除网页中的内嵌广告脚本。不能保证100%成功,可以在脚本菜单中管理排除的网页和关键词,脚本已经内置一些常见的关键词,若还有广告,可以自行添加Math.random,platform,navigator,new Function,new Date()尝试去除。 // @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_setValue // @grant GM_getValue // @grant GM_registerMenuCommand // @run-at document-start // @downloadURL https://openuserjs.org/install/Aloazny123/%E7%A7%BB%E9%99%A4%E5%B9%BF%E5%91%8A%E5%86%85%E5%B5%8C%E8%84%9A%E6%9C%AC.user.js // @updateURL https://openuserjs.org/meta/Aloazny123/%E7%A7%BB%E9%99%A4%E5%B9%BF%E5%91%8A%E5%86%85%E5%B5%8C%E8%84%9A%E6%9C%AC.meta.js // ==/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]}', '/image/202${scripts[Math.random()', '"https://"+Date.parse(new Date())+', '"https://"+(new Date().getDate())+', 'new Function(t)()', 'new Function(b)()', 'new Function(\'d\',e)', 'Math.floor(2147483648 * Math.random());', 'Math.floor(Math.random()*url.length)', '&&navigator[', '=navigator;', 'navigator.platform){setTimeout(function', '¥ 666:/', 'disableDebugger', 'sojson.v', '<\\/\'+\'s\'+\'c\'+\'ri\'+\'pt\'+\'>\');', 'histats.com', 'pc.stgowan.com', 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789' ]; let keywords = GM_getValue(REMOVE_AD_SCRIPTS_KEYWORDS_KEY, []); let excludeList = GM_getValue(EXCLUDE_SITES_KEY, []); let removedScriptsInfo = []; function saveKeywords() { GM_setValue(REMOVE_AD_SCRIPTS_KEYWORDS_KEY, keywords); } function saveExcludeList() { GM_setValue(EXCLUDE_SITES_KEY, excludeList); } function getKeywordsForCurrentSite() { const siteKeywords = keywords.filter(keyword => keyword.startsWith(`${window.location.hostname}:`)) .map(keyword => keyword.split(':').slice(1).join(':')); return siteKeywords.length > 0 ? siteKeywords : DEFAULT_KEYWORDS; } function removeSpecificScript() { if (excludeList.includes(window.location.hostname)) { console.log('Current site is excluded:', window.location.hostname); return; } const currentKeywords = getKeywordsForCurrentSite(); document.querySelectorAll('script').forEach(script => { const matchedKeywords = currentKeywords.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) { let siteKeywords = getKeywordsForCurrentSite(); siteKeywords = siteKeywords.concat(DEFAULT_KEYWORDS); keywords.push(`${window.location.hostname}:${newKeyword}`); saveKeywords(); alert('关键词已添加: ' + newKeyword); } } function showKeywords() { const allKeywords = getKeywordsForCurrentSite(); alert('当前关键词:\n' + allKeywords.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.slice(0, 1000)}\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' }); const siteKeywords = keywords.filter(keyword => keyword.startsWith(`${window.location.hostname}:`)) .map(keyword => keyword.split(':').slice(1).join(':')) .join('\n'); editor.value = siteKeywords.length > 0 ? siteKeywords : DEFAULT_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 = () => { const newKeywords = editor.value.split('\n') .map(k => k.trim()) .filter(k => k) .map(k => `${window.location.hostname}:${k}`); keywords = keywords.filter(keyword => !keyword.startsWith(`${window.location.hostname}:`)) .concat(newKeywords); saveKeywords(); document.body.removeChild(overlay); document.body.removeChild(editorContainer); alert('关键词已更新'); }; resetButton.onclick = () => { if (confirm('确定重置为默认关键词?')) { keywords = keywords.filter(keyword => !keyword.startsWith(`${window.location.hostname}:`)); editor.value = DEFAULT_KEYWORDS.join('\n'); saveKeywords(); 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); })();