Greasy Fork

Greasy Fork is available in English.

红石中继站去中间页

智能单跳转策略+页面元素处理

当前为 2025-02-03 提交的版本,查看 最新版本

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴Greasemonkey 油猴子Violentmonkey 暴力猴,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴Violentmonkey 暴力猴,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴Userscripts ,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展后才能安装此脚本。

(我已经安装了用户脚本管理器,让我安装!)

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

(我已经安装了用户样式管理器,让我安装!)

// ==UserScript==
// @name         红石中继站去中间页
// @version      0.2
// @description  智能单跳转策略+页面元素处理
// @author       28074
// @match        *://www.mczwlt.net/*
// @grant        GM_openInTab
// @grant        window.close
// @grant        unsafeWindow
// @run-at       document-start
// @icon         https://www.mczwlt.net/favicon.ico
// @license MIT
// @namespace http://greasyfork.icu/users/1429810
// ==/UserScript==



(function() {
    'use strict';
    const unsafeWindow = window.wrappedJSObject || window;

    const decodeUrl = (encoded) => {
        try {
            let decoded = encoded;
            for(let i = 0; i < 3; i++) {
                if (/%[0-9A-Fa-f]{2}/.test(decoded)) {
                    decoded = decodeURIComponent(decoded);
                } else break;
            }
            return new URL(decoded).href;
        } catch(e) {
            console.error('URL解码失败:', e);
            return null;
        }
    };

    const handleInstantRedirect = () => {
        if (!location.pathname.includes('/go-external')) return;

        const urlParam = new URLSearchParams(location.search).get('url');
        if (!urlParam) return;

        const targetUrl = decodeUrl(urlParam);
        if (!targetUrl) return;

        window.stop();
        document.documentElement.innerHTML = '';

        GM_openInTab(targetUrl, { active: true });

        setTimeout(() => {
            window.close();
        });
    };

    const handlePageElements = () => {
        const replaceLinks = () => {
            document.querySelectorAll('a[href*="/go-external"]').forEach(link => {
                const match = link.href.match(/url=([^&]+)/);
                if (!match) return;

                const realUrl = decodeUrl(match[1]);
                if (!realUrl) return;

                const newLink = link.cloneNode(true);
                newLink.href = realUrl;

                const cleanLink = newLink.cloneNode(true);
                cleanLink.onclick = e => {
                    e.preventDefault();
                    GM_openInTab(realUrl, { active: true });
                };

                link.replaceWith(cleanLink);
            });
        };

        replaceLinks();

        new MutationObserver(replaceLinks).observe(document.body, {
            childList: true,
            subtree: true
        });

        if (unsafeWindow.$router?.push) {
            const originalPush = unsafeWindow.$router.push;
            unsafeWindow.$router.push = function(location) {
                if (location.path === '/external-link-warn' && location.query?.url) {
                    const realUrl = decodeUrl(location.query.url);
                    return realUrl ? GM_openInTab(realUrl) : originalPush(...arguments);
                }
                return originalPush(...arguments);
            };
        }
    };

    if (location.pathname.includes('/go-external')) {
        handleInstantRedirect();
    } else {
        if (document.readyState === 'loading') {
            document.addEventListener('DOMContentLoaded', handlePageElements);
        } else {
            handlePageElements();
        }
    }
})();