// ==UserScript==
// @name 移除广告内嵌脚本
// @namespace https://greasyfork.org/zh-CN/users/1373566
// @version 1.4.9.7
// @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
// ==/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\'+\'>\');',
'</\'+\'s\'+\'c\'+\'ri\'+\'pt\'+\'>\');',
'histats.com',
'pc.stgowan.com'
];
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) {
const siteHostname = window.location.hostname;
const newSiteKeyword = `${siteHostname}:${newKeyword}`;
const existingSiteKeywords = keywords.filter(keyword => keyword.startsWith(`${siteHostname}:`));
if (!existingSiteKeywords.some(keyword => DEFAULT_KEYWORDS.some(defaultKeyword => keyword.includes(defaultKeyword)))) {
const defaultSiteKeywords = DEFAULT_KEYWORDS.map(keyword => `${siteHostname}:${keyword}`);
keywords.push(...defaultSiteKeywords);
}
keywords.push(newSiteKeyword);
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);
})();