移除广告内嵌脚本

这是一个由AI生成的脚本,通过关键词匹配来移除网页中的内嵌广告脚本。不能保证100%成功,可以在脚本菜单中管理排除的网页和关键词,脚本已经内置一些常见的关键词,若还有广告,可以自行添加Math.random,platform,navigator,new Function,new Date()尝试去除。

安裝腳本?
作者推薦腳本

您可能也會喜歡 加多重buff的广告拦截脚本

安裝腳本
// ==UserScript==
// @name         移除广告内嵌脚本
// @namespace   https://gf.qytechs.cn/zh-CN/users/1373566
// @version      1.5.1.5
// @license      MIT
// @description  这是一个由AI生成的脚本,通过关键词匹配来移除网页中的内嵌广告脚本。不能保证100%成功,可以在脚本菜单中管理排除的网页和关键词,脚本已经内置一些常见的关键词,若还有广告,可以自行添加Math.random,platform,navigator,new Function,new Date()尝试去除。
// @author       copilot & cheatgpt
// @match        http*://*/*
// @exclude      *://*.github.com/*
// @exclude      *://scriptcat.org/*
// @exclude      *://gf.qytechs.cn/*
// @exclude      *://github.com/*
// @exclude      *://*.google.*/*
// @exclude      *://x.com/*
// @exclude      *://twitter.com/*
// @exclude      *://*.bing.*/*
// @exclude      *://*.baidu.*/*
// @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 = [
        'htmlAds',
        '_ffc1();',
        '_ffc2();',
        '_ffc3();',
        '_ffc4();',
        '_ffp();',
        'kbbaidu1();',
        'kbbaidu2();',
        'kbbaidu3();',
        'html5player.checkVideoAds',
        'ads_codes',
        '{return void 0!==b[a]?b[a]:a}).join("")}',
        '-${scripts[randomIndex]}',
        '-${scripts[Math.random()',
        '"https://"+Date.parse(new Date())+',
        '"https://"+(new Date().getDate())+',
        'https://hongosi.xn--',
        'https://{randomstr}.',
        'new Function(t)()',
        'new Function(b)()',
        'new Function(c)()',
        'new Function(t);',
        'new Function(b);',
        'new Function(c);',
        'new Function(\'d\',e)',
        'new Function(document[',
        'function updateCarousel()',
        'Math.floor(2147483648 * Math.random());',
        'Math.floor(Math.random()*url.length)',
        'Math.floor(Math.random() * urls.length)',
        'new Date()[\'getTime\']()',
        'Math.floor(((new Date()).getTime()',
        '&&navigator[',
        '=navigator;',
        'navigator.platform){setTimeout(function',
        'disableDebugger',
        'blockDeveloperTools',
        '["Date"]())[\'getTime\']()',
        '</\'+\'s\'+\'c\'+\'ri\'+\'pt\'+\'>\');',
        '<\\/\'+\'s\'+\'c\'+\'ri\'+\'pt\'+\'>\');',
        'class=\\"zdhf\\"',
        '(\'#htmlContenthtml\').html',
        'D.createElement(\'span\');',
        'class=\\"app_tj\\"',
        'window.$m(',
        'jsjiami.com.v4',
        'histats.com',
        'pc.stgowan.com'
    ];
    let keywords = GM_getValue(REMOVE_AD_SCRIPTS_KEYWORDS_KEY, []);
    let excludeList = GM_getValue(EXCLUDE_SITES_KEY, []);
    let removedScriptsInfo = [];

    const saveKeywords = () => GM_setValue(REMOVE_AD_SCRIPTS_KEYWORDS_KEY, keywords);
    const saveExcludeList = () => GM_setValue(EXCLUDE_SITES_KEY, excludeList);
    const createStyledElement = (tagName, styles) => {
        const element = document.createElement(tagName);
        Object.assign(element.style, styles);
        return element;
    };
    const getKeywordsForCurrentSite = () => {
        const siteKeywords = keywords
            .filter(k => k.startsWith(`${window.location.hostname}:`))
            .map(k => k.split(':').slice(1).join(':'));
        return siteKeywords.length > 0 ? siteKeywords : DEFAULT_KEYWORDS;
    };
    const removeSpecificScript = () => {
        if (excludeList.includes(window.location.hostname)) {
            console.log('Site excluded:', window.location.hostname);
            return;
        }
        const currentKeywords = getKeywordsForCurrentSite();
        document.querySelectorAll('script').forEach(script => {
            const matchedKeywords = currentKeywords.filter(k => script.innerHTML.includes(k));
            if (matchedKeywords.length) {
                removedScriptsInfo.push({
                    keywords: matchedKeywords,
                    content: script.innerHTML
                });
                script.remove();
                console.log('Removed script:', script);
            }
        });
    };
    const addKeyword = () => {
        const newKeyword = prompt('请输入要添加的关键词:');
        if (newKeyword) {
            const siteKeyword = `${window.location.hostname}:${newKeyword}`;
            if (!keywords.some(k => k.startsWith(`${window.location.hostname}:`))) {
                keywords.push(...DEFAULT_KEYWORDS.map(k => `${window.location.hostname}:${k}`));
            }
            keywords.push(siteKeyword);
            saveKeywords();
            alert(`关键词已添加: ${newKeyword}`);
        }
    };
    const showKeywords = () => alert('当前关键词:\n' + getKeywordsForCurrentSite().join('\n'));
    const showRemovedScriptsInfo = () => {
        if (!removedScriptsInfo.length) return alert('没有移除任何脚本。');
        const info = removedScriptsInfo.map((item, i) =>
            `脚本 ${i + 1}:\n匹配关键词: ${item.keywords.join(', ')}\n脚本内容:\n${item.content.slice(0, 1000)}\n`
        ).join('\n');
        alert('移除的脚本信息:\n\n' + info);
    };
    const manageSite = operation => {
        const site = window.location.hostname;
        if (operation === 'exclude' && !excludeList.includes(site)) {
            excludeList.push(site);
            saveExcludeList();
            alert(`当前网址已排除: ${site}`);
        } else if (operation === 'add' && excludeList.includes(site)) {
            excludeList = excludeList.filter(s => s !== site);
            saveExcludeList();
            alert(`当前网址已从排除列表移除: ${site}`);
        } else {
            alert(`当前网址${operation === 'exclude' ? '已在' : '不在'}排除列表中`);
        }
    };
    const 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 container = 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',
            border: '2px solid #4a90e2',
            borderRadius: '4px',
            padding: '15px',
            fontFamily: 'monospace',
            fontSize: '14px'
        });
        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'
        };
        editor.value = getKeywordsForCurrentSite().join('\n');
        const saveButton = createStyledElement('button', {
            ...buttonStyle,
            backgroundColor: '#4CAF50'
        });
        saveButton.textContent = '保存';
        saveButton.onclick = () => {
            keywords = keywords.filter(k => !k.startsWith(`${window.location.hostname}:`))
                .concat(editor.value.split('\n').map(k => k.trim()).filter(k => k).map(k => `${window.location.hostname}:${k}`));
            saveKeywords();
            document.body.removeChild(overlay);
            document.body.removeChild(container);
            alert('关键词已更新');
        };
        const resetButton = createStyledElement('button', {
            ...buttonStyle,
            backgroundColor: '#f44336'
        });
        resetButton.textContent = '重置';
        resetButton.onclick = () => {
            if (confirm('确定重置为默认关键词?')) {
                keywords = keywords.filter(k => !k.startsWith(`${window.location.hostname}:`));
                editor.value = DEFAULT_KEYWORDS.join('\n');
                saveKeywords();
                alert('已恢复默认关键词');
            }
        };
        buttonContainer.append(saveButton, resetButton);
        container.append(editor, buttonContainer);
        document.body.append(overlay, container);
    };
    const showInlineScripts = () => {
        const scripts = Array.from(document.querySelectorAll('script'))
            .filter(s => s.innerHTML.trim())
            .map((s, i) => `脚本 ${i + 1}:\n${s.innerHTML.trim()}\n`)
            .join('\n');
        alert(scripts ? '网页中的内嵌脚本:\n\n' + scripts : '没有找到内嵌脚本');
    };
    const cleanGMData = () => {
        const siteMap = {};
        keywords.forEach(k => {
            const [site, ...rest] = k.split(':');
            const key = rest.join(':');
            siteMap[site] = siteMap[site] || new Set();
            siteMap[site].add(key);
        });
        const sites = Object.keys(siteMap);
        if (!sites.length) return alert('没有找到任何网站数据');
        const overlay = createStyledElement('div', {
            position: 'fixed',
            top: 0,
            left: 0,
            width: '100%',
            height: '100%',
            backgroundColor: 'rgba(0,0,0,0.5)',
            zIndex: '9998'
        });
        const container = createStyledElement('div', {
            position: 'fixed',
            top: '50%',
            left: '50%',
            transform: 'translate(-50%, -50%)',
            zIndex: '9999',
            width: '80vw',
            maxWidth: '600px',
            backgroundColor: '#f8f9fa',
            borderRadius: '8px',
            padding: '20px',
            maxHeight: '80vh',
            overflowY: 'auto'
        });
        const title = createStyledElement('h3', {
            margin: '0 0 15px 0',
            color: '#212529'
        });
        title.textContent = '选择清理方式';

        const select = createStyledElement('select', {
            width: '100%',
            padding: '8px',
            marginBottom: '15px',
            borderRadius: '4px',
            border: '1px solid #4a90e2'
        });
        select.innerHTML = '<option value="all">清理所有默认关键词数据</option><option value="specific">选择特定网站清理</option>';

        const siteSelectContainer = createStyledElement('div', {
            display: 'none',
            marginBottom: '15px'
        });
        const siteSelect = createStyledElement('select', {
            width: '100%',
            padding: '8px',
            borderRadius: '4px',
            border: '1px solid #4a90e2'
        });
        siteSelect.innerHTML = '<option value="">选择网站</option>' + sites.map(s => `<option value="${s}">${s}</option>`).join('');
        siteSelectContainer.appendChild(siteSelect);

        select.onchange = () => siteSelectContainer.style.display = select.value === 'specific' ? 'block' : 'none';

        const buttonContainer = createStyledElement('div', {
            display: 'flex',
            gap: '10px',
            justifyContent: 'flex-end'
        });
        const buttonStyle = {
            padding: '8px 20px',
            color: 'white',
            border: 'none',
            borderRadius: '4px',
            cursor: 'pointer',
            fontSize: '14px'
        };

        const confirmButton = createStyledElement('button', {
            ...buttonStyle,
            backgroundColor: '#4CAF50'
        });
        confirmButton.textContent = '确认';
        confirmButton.onclick = () => {
            const mode = select.value;
            let report = 'GM数据清理报告:\n\n';
            let cleanedCount = 0;
            const defaultSet = new Set(DEFAULT_KEYWORDS);

            if (mode === 'all') {
                if (!confirm('确定要清理所有与默认关键词一致的数据吗?')) return;
                const sitesToRemove = [];
                for (const site in siteMap) {
                    const siteKeywords = siteMap[site];
                    const isExactMatch = siteKeywords.size === defaultSet.size && [...siteKeywords].every(k => defaultSet.has(k)) && [...defaultSet].every(k => siteKeywords.has(k));
                    report += `网站: ${site}\n关键词数量: ${siteKeywords.size}\n`;
                    if (isExactMatch) {
                        sitesToRemove.push(site);
                        cleanedCount++;
                    } else {
                        if (siteKeywords.size !== defaultSet.size) {
                            report += `原因: 数量不匹配 (默认: ${defaultSet.size}, 网站: ${siteKeywords.size})\n`;
                        }
                        const extraKeywords = [...siteKeywords].filter(k => !defaultSet.has(k));
                        const missingKeywords = [...defaultSet].filter(k => !siteKeywords.has(k));
                        if (extraKeywords.length > 0) {
                            report += `原因: 多余关键词: ${extraKeywords.join(', ')}\n`;
                        }
                        if (missingKeywords.length > 0) {
                            report += `原因: 缺少关键词: ${missingKeywords.join(', ')}\n`;
                        }
                        report += '\n';
                    }
                }
                if (cleanedCount) {
                    keywords = keywords.filter(k => !sitesToRemove.some(s => k.startsWith(`${s}:`)));
                    saveKeywords();
                    report += `共清理 ${cleanedCount} 个与默认关键词一致的网站数据`;
                } else {
                    report += '没有找到与默认关键词完全一致的网站数据';
                }
            } else if (mode === 'specific') {
                const selectedSite = siteSelect.value;
                if (!selectedSite) return alert('请选择一个网站');
                if (!confirm(`确定要清理 ${selectedSite} 的关键词数据吗?`)) return;
                const siteKeywords = siteMap[selectedSite];
                report += `网站: ${selectedSite}\n关键词数量: ${siteKeywords.size}\n关键词: ${[...siteKeywords].join(', ')}\n\n`;
                keywords = keywords.filter(k => !k.startsWith(`${selectedSite}:`));
                saveKeywords();
                report += `已清理 ${selectedSite} 的所有关键词数据`;
                cleanedCount = 1;
            }
            document.body.removeChild(overlay);
            document.body.removeChild(container);
            alert(report);
        };
        const cancelButton = createStyledElement('button', {
            ...buttonStyle,
            backgroundColor: '#f44336'
        });
        cancelButton.textContent = '取消';
        cancelButton.onclick = () => {
            document.body.removeChild(overlay);
            document.body.removeChild(container);
        };
        buttonContainer.append(confirmButton, cancelButton);
        container.append(title, select, siteSelectContainer, buttonContainer);
        document.body.append(overlay, container);
    };
    const observer = new MutationObserver(mutations => {
        mutations.forEach(m => {
            m.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);
    GM_registerMenuCommand('GM关键词数据清理', cleanGMData);
})();

QingJ © 2025

镜像随时可能失效,请加Q群300939539或关注我们的公众号极客氢云获取最新地址