Greasy Fork

来自缓存

Greasy Fork is available in English.

全网VIP视频免费破解去广告-alienzy自用版

全网VIP视频免费破解去广告,适配PC+移动,全网VIP视频解析:爱奇艺、腾讯、优酷、bilibili等视频免费解析!鼠标左键拖拽,支持本页解析和跳转解析!🔥真4K高清🔥脚本长期维护更新,完全免费,无广告,仅限学习交流!

您需要先安装一个扩展,例如 篡改猴Greasemonkey暴力猴,之后才能安装此脚本。

You will need to install an extension such as Tampermonkey to install this script.

您需要先安装一个扩展,例如 篡改猴暴力猴,之后才能安装此脚本。

您需要先安装一个扩展,例如 篡改猴Userscripts ,之后才能安装此脚本。

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

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

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

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

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

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

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

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

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

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

// ==UserScript==
// @name              全网VIP视频免费破解去广告-alienzy自用版
// @namespace         http://tampermonkey.net/
// @version           0.1.0
// @description       全网VIP视频免费破解去广告,适配PC+移动,全网VIP视频解析:爱奇艺、腾讯、优酷、bilibili等视频免费解析!鼠标左键拖拽,支持本页解析和跳转解析!🔥真4K高清🔥脚本长期维护更新,完全免费,无广告,仅限学习交流!
// @icon              
// @author            https://blog.alienzy.top/vipjx
// @include           *://v.qq.com/x/page/*
// @include           *://v.qq.com/x/cover/*
// @include           *://v.qq.com/tv/*
// @include           *://*.iqiyi.com/v_*
// @include           *://*.iqiyi.com/a_*
// @include           *://*.iqiyi.com/w_*
// @include           *://*.iq.com/play/*
// @include           *://*.youku.com/v_*
// @include           *://*.youku.com/video*
// @include           *://*.youku.com/*?vid=*
// @include           *://*.mgtv.com/b/*
// @include           *://*.tudou.com/v_*
// @include           *://tv.sohu.com/v/*
// @include           *://*.bilibili.com/video/*
// @include           *://*.bilibili.com/bangumi/play/*
// @include           *://v.pptv.com/show/*
// @include           *://vip.pptv.com/show/*
// @include           *://www.wasu.cn/Play/show/*
// @include           *://*.le.com/ptv/vplay/*
// @include           *://*.acfun.cn/v/*
// @include           *://*.acfun.cn/bangumi/*
// @include           *://*.1905.com/play/*
// @include           *://m.v.qq.com/x/m/*
// @include           *://m.v.qq.com/*
// @include           *://m.iqiyi.com/*
// @include           *://m.iqiyi.com/v_*
// @include           *://m.youku.com/video/*
// @include           *://m.youku.com/alipay_*
// @include           *://m.mgtv.com/b/*
// @include           *://m.tv.sohu.com/v/*
// @include           *://m.tv.sohu.com/album/*
// @include           *://m.pptv.com/show/*
// @include           *://m.bilibili.com/anime/*
// @include           *://m.bilibili.com/video/*
// @include           *://m.bilibili.com/bangumi/play/*
// @require           https://mirrors.sustech.edu.cn/cdnjs/ajax/libs/jquery/3.7.1/jquery.min.js
// @connect           api.bilibili.com
// @grant             unsafeWindow
// @grant             GM_addStyle
// @grant             GM_openInTab
// @grant             GM_getValue
// @grant             GM_setValue
// @grant             GM_xmlhttpRequest
// @charset           UTF-8
// @license           GPL License
// ==/UserScript==

const util = (function () {
    function findTargetElement(targetContainer) {
        const body = window.document;
        let tabContainer;
        let tryTime = 0;
        const maxTryTime = 120;
        return new Promise((resolve, reject) => {
            let interval = setInterval(() => {
                tabContainer = body.querySelector(targetContainer);
                if (tabContainer) {
                    clearInterval(interval);
                    resolve(tabContainer);
                }
                if ((++tryTime) === maxTryTime) {
                    clearInterval(interval);
                    reject(new Error(`未找到元素: ${targetContainer}`));
                }
            }, 500);
        });
    }

    function urlChangeReload() {
        const oldHref = window.location.href;
        let interval = setInterval(() => {
            let newHref = window.location.href;
            if (oldHref !== newHref) {
                clearInterval(interval);
                window.location.reload();
            }
        }, 500);
    }

    function reomveVideo() {
        setInterval(() => {
            for (let video of document.getElementsByTagName("video")) {
                if (video.src) {
                    video.removeAttribute("src");
                    video.muted = true;
                    video.load();
                    video.pause();
                }
            }
        }, 500);
    }

    function syncRequest(option) {
        return new Promise((resolve, reject) => {
            option.onload = (res) => resolve(res);
            option.onerror = (err) => reject(err);
            GM_xmlhttpRequest(option);
        });
    }

    return {
        req: (option) => syncRequest(option),
        findTargetEle: (targetEle) => findTargetElement(targetEle),
        urlChangeReload: () => urlChangeReload(),
        reomveVideo: () => reomveVideo()
    }
})();


const superVip = (function () {
    const _CONFIG_ = {
        isMobile: navigator.userAgent.match(/(Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini)/i),
        currentPlayerNode: null,
        vipBoxId: 'vip_jx_box' + Math.ceil(Math.random() * 100000000),
        totalAreaId: 'vip_total_area' + Math.ceil(Math.random() * 100000000),
        flag: "flag_vip",
        videoParseList: [
            {"name": "789解析", "type": "1,3", "url": "https://jiexi.789jiexi.icu:4433/?url="},
            {"name": "极速解析", "type": "1,3", "url": "https://jx.2s0.cn/player/?url="},
            {"name": "冰豆解析", "type": "1,3", "url": "https://bd.jx.cn/?url="},
            {"name": "973解析", "type": "1,3", "url": "https://jx.973973.xyz/?url="},
            {"name": "Player-JY", "type": "1,3", "url": "https://jx.playerjy.com/?url="},
            {"name": "虾米视频解析", "type": "1,3", "url": "https://jx.xmflv.com/?url="},
            {"name": "CK", "type": "1,3", "url": "https://www.ckplayer.vip/jiexi/?url="},
            {"name": "七哥解析", "type": "1,3", "url": "https://jx.nnxv.cn/tv.php?url="},
            {"name": "夜幕", "type": "1,3", "url": "https://www.yemu.xyz/?url="},
            {"name": "盘古", "type": "1,3", "url": "https://www.pangujiexi.com/jiexi/?url="},
            {"name": "playm3u8", "type": "1,3", "url": "https://www.playm3u8.cn/jiexi.php?url="},
            {"name": "七七云解析", "type": "1,3", "url": "https://jx.77flv.cc/?url="},
            {"name": "芒果TV1", "type": "1,3", "url": "https://video.isyour.love/player/getplayer?url="},
            {"name": "芒果TV2", "type": "1,3","url":"https://im1907.top/?jx="},
            {"name": "HLS解析", "type": "1,3", "url": "https://jx.hls.one/?url="},
        ],
        playerContainers: [
            {host: "v.qq.com", container: "#mod_player,#player-container,.container-player", name: "Default", displayNodes: ["#mask_layer", ".mod_vip_popup", "#mask_layer", ".panel-tip-pay"]},
            {host: "m.v.qq.com", container: ".mod_player,#player", name: "Default", displayNodes: [".mod_vip_popup", "[class^=app_],[class^=app-],[class*=_app_],[class*=-app-],[class$=_app],[class$=-app]", "div[dt-eid=open_app_bottom]", "div.video_function.video_function_new", "a[open-app]", "section.mod_source", "section.mod_box.mod_sideslip_h.mod_multi_figures_h,section.mod_sideslip_privileges,section.mod_game_rec"]},
            {host: "w.mgtv.com", container: "#mgtv-player-wrap", name: "Default", displayNodes: []},
            {host: "www.mgtv.com", container: "#mgtv-player-wrap", name: "Default", displayNodes: []},
            {host: "m.mgtv.com", container: ".video-area", name: "Default", displayNodes: ["div.adFixedContain,div.ad-banner,div.m-list-graphicxcy.fstp-mark", "div[class^=mg-app],div#comment-id.video-comment div.ft,div.bd.clearfix,div.v-follower-info", "div.ht.mgui-btn.mgui-btn-nowelt", "div.personal", "div[data-v-41c9a64e]"]},
            {host: "www.bilibili.com", container: "#player_module,#bilibiliPlayer,#bilibili-player", name: "Default", displayNodes: []},
            {host: "m.bilibili.com", container: ".player-wrapper,.player-container,.mplayer", name: "Default", displayNodes: []},
            {host: "www.iqiyi.com", container: "#outlayer, .iqp-player-videolayer", name: "Default", displayNodes: ["#playerPopup", "#vipCoversBox" ,"div.iqp-player-vipmask", "div.iqp-player-paymask","div.iqp-player-loginmask", "div[class^=qy-header-login-pop]",".covers_cloudCover__ILy8R","#videoContent > div.loading_loading__vzq4j",".iqp-player-guide"]},
            {host: "m.iqiyi.com", container: ".m-video-player-wrap, .iqp-player-videolayer", name: "Default", displayNodes: ["div.m-iqyGuide-layer", "a[down-app-android-url]", "div.iqp-player-vipmask", ".loading_loading__vzq4j","[name=m-extendBar]", "[class*=ChannelHomeBanner]", "section.m-hotWords-bottom"]},
            {host: "www.iq.com", container: ".intl-video-wrap", name: "Default", displayNodes: []},
            {host: "v.youku.com", container: "#playerMouseWheel", name: "Default", displayNodes: ["#iframaWrapper"]},
            {host: "m.youku.com", container: "#playerMouseWheel,.h5-detail-player", name: "Default", displayNodes: []},
            {host: "tv.sohu.com", container: "#player", name: "Default", displayNodes: []},
            {host: "film.sohu.com", container: "#playerWrap", name: "Default", displayNodes: []},
            {host: "www.le.com", container: "#le_playbox", name: "Default", displayNodes: []},
            {host: "video.tudou.com", container: ".td-playbox", name: "Default", displayNodes: []},
            {host: "v.pptv.com", container: "#pptv_playpage_box", name: "Default", displayNodes: []},
            {host: "vip.pptv.com", container: ".w-video", name: "Default", displayNodes: []},
            {host: "www.wasu.cn", container: "#flashContent", name: "Default", displayNodes: []},
            {host: "www.acfun.cn", container: "#player", name: "Default", displayNodes: []},
            {host: "vip.1905.com", container: "#player,#vodPlayer", name: "Default", displayNodes: []},
            {host: "www.1905.com", container: "#player,#vodPlayer", name: "Default", displayNodes: []},
        ]
    };

    class BaseConsumer {
        constructor() {
            this.parse = () => {
                util.findTargetEle('body')
                    .then((body) => this.initPlayerNode())
                    .then(() => this.preHandle())
                    .then(() => this.generateElement())
                    .then(() => this.bindEvent())
                    .then(() => this.postHandle())
                    .catch(err => console.error("初始化失败:", err));
            }
        }

        initPlayerNode() {
            return new Promise((resolve) => {
                const currentHost = window.location.host;
                _CONFIG_.currentPlayerNode = _CONFIG_.playerContainers.find(container =>
                    currentHost.includes(container.host)
                );
                if (!_CONFIG_.currentPlayerNode) {
                    _CONFIG_.currentPlayerNode = {
                        container: "video",
                        displayNodes: []
                    };
                }
                resolve();
            });
        }

        preHandle() {
            return new Promise((resolve) => {
                _CONFIG_.currentPlayerNode.displayNodes.forEach((selector) => {
                    util.findTargetEle(selector)
                        .then((el) => el.style.display = 'none')
                        .catch(() => {});
                });
                resolve();
            });
        }

        generateElement() {
            return new Promise((resolve) => {
                GM_addStyle(`
                    #${_CONFIG_.totalAreaId} {
                        position: fixed;
                        top: 50%;
                        left: 20px;
                        transform: translateY(-50%);
                        z-index: 99999999;
                        display: inline-block;
                        padding: 5px;
                    }

                    #${_CONFIG_.vipBoxId} {
                        display: flex;
                        flex-direction: column;
                        align-items: center;
                        gap: 15px;
                        float: left;
                    }

                    .control-btn {
                        width: 63px;
                        height: 63px;
                        border-radius: 50%;
                        display: flex;
                        align-items: center;
                        justify-content: center;
                        font-size: 12px; /* 减小字体大小 */
                        font-weight: bold;
                        cursor: pointer;
                        color: white;
                        box-shadow: 0 3px 10px rgba(0,0,0,0.3);
                        transition: all 0.3s ease;
                        z-index: 10;
                        text-align: center;
                        line-height: 1.2; /* 调整行高以适应小字体 */
                        padding: 5px;
                        word-break: break-word; /* 允许文字换行 */
                    }

                    .vip-main { background-color: #7d4aee; }
                    .inline-btn { background-color: #28a745; }
                    .popup-btn {
                        background-color: #ffc107; /* 黄色背景 */
                        color: black; /* 黑色文字,提高可读性 */
                    }

                    .inline-btn, .popup-btn {
                        opacity: 0;
                        visibility: hidden;
                        transform: translateX(-20px);
                        transition: all 0.3s ease;
                    }

                    #${_CONFIG_.totalAreaId}.active .inline-btn,
                    #${_CONFIG_.totalAreaId}.active .popup-btn {
                        opacity: 1;
                        visibility: visible;
                        transform: translateX(0);
                    }

                    .vip-list {
                        display: none;
                        float: left;
                        margin-left: 15px;
                        margin-top: 20px;
                        background: #3f4149;
                        border: 1px solid white;
                        border-radius: 5px;
                        width: 380px;
                        max-height: 400px;
                        overflow-y: auto;
                        padding: 10px 0;
                        box-shadow: 0 5px 15px rgba(0,0,0,0.3);
                        z-index: 5;
                    }

                    .vip-list.show {
                        display: block;
                    }

                    .list-section { display: none; }
                    .list-section.active { display: block; }

                    .vip-list li {
                        float: left;
                        width: calc(25% - 14px);
                        margin: 4px 2px;
                        padding: 0 4px;
                        line-height: 21px;
                        font-size: 12px;
                        color: #E6E6E6;
                        border: 1px solid gray;
                        border-radius: 2px;
                        overflow: hidden;
                        white-space: nowrap;
                        text-overflow: ellipsis;
                        cursor: pointer;
                        user-select: none;
                    }

                    .vip-list li:hover {
                        color: #00dffc;
                        border-color: #00dffc;
                    }

                    .vip-list h3 {
                        color: #00dffc;
                        font-size: 16px;
                        padding: 5px 10px;
                        margin: 0;
                        text-align: left;
                    }

                    .vip-list ul {
                        padding: 0 10px;
                        margin: 0;
                        list-style: none;
                    }

                    .info {
                        padding: 10px;
                        color: #FFF;
                        font-size: 10px;
                        text-align: left;
                    }

                    li.selected {
                        color: #00dffc;
                        border: 1px solid #00dffc;
                    }
                `);

                let type1List = "";
                let type3List = "";
                _CONFIG_.videoParseList.forEach((item, index) => {
                    if (item.type.includes("1")) {
                        type1List += `<li class="nq-li" data-index="${index}">${item.name}</li>`;
                    }
                    if (item.type.includes("3")) {
                        type3List += `<li class="tc-li" data-index="${index}">${item.name}</li>`;
                    }
                });

                const html = `
                    <div id="${_CONFIG_.totalAreaId}">
                        <div id="${_CONFIG_.vipBoxId}">
                            <div class="control-btn inline-btn" title="内嵌播放解析源">内嵌播放</div>
                            <div class="control-btn vip-main" title="VIP解析菜单">VIP</div>
                            <div class="control-btn popup-btn" title="跳转播放解析源">跳转播放</div>
                        </div>
                        <div class="vip-list">
                            <div class="list-section" id="inline-list">
                                <h3>内嵌播放</h3>
                                <ul>${type1List}<div style="clear:both;"></div></ul>
                            </div>
                            <div class="list-section" id="popup-list">
                                <h3>跳转播放</h3>
                                <ul>${type3List}<div style="clear:both;"></div></ul>
                            </div>
                            <div class="info">
                                <b>使用说明:</b><br>
                                1. 内嵌播放:在当前页面内嵌播放视频<br>
                                2. 跳转播放:在新页面打开播放器
                            </div>
                        </div>
                    </div>
                `;

                $("body").prepend(html);
                resolve();
            });
        }

        bindEvent() {
            return new Promise((resolve) => {
                const totalArea = $(`#${_CONFIG_.totalAreaId}`);
                const vipBox = $(`#${_CONFIG_.vipBoxId}`);
                const vipList = totalArea.find(".vip-list");
                const inlineBtn = vipBox.find(".inline-btn");
                const popupBtn = vipBox.find(".popup-btn");
                const vipMainBtn = vipBox.find(".vip-main");
                const inlineList = vipList.find("#inline-list");
                const popupList = vipList.find("#popup-list");

                const showList = (section) => {
                    vipList.addClass("show");
                    inlineList.removeClass("active");
                    popupList.removeClass("active");
                    section.addClass("active");
                    totalArea.addClass("active");
                };

                const hideList = () => {
                    vipList.removeClass("show");
                    inlineList.removeClass("active");
                    popupList.removeClass("active");
                };

                const hideAll = () => {
                    totalArea.removeClass("active");
                    hideList();
                };

                // VIP主按钮交互
                vipMainBtn.on('mouseenter', () => totalArea.addClass("active"));

                // 内嵌按钮交互
                inlineBtn.on('mouseenter', () => {
                    totalArea.addClass("active");
                    showList(inlineList);
                });
                inlineBtn.on('click', () => showList(inlineList));

                // 跳转按钮交互
                popupBtn.on('mouseenter', () => {
                    totalArea.addClass("active");
                    showList(popupList);
                });
                popupBtn.on('click', () => showList(popupList));

                // 整体区域离开时隐藏
                totalArea.on('mouseleave', () => {
                    hideAll();
                });

                // 内嵌播放点击事件
                const _this = this;
                vipList.on('click', '.nq-li', function(e) {
                    e.stopPropagation();
                    const index = parseInt($(this).data("index"));
                    GM_setValue(_CONFIG_.flag, "true");
                    _this.showPlayerWindow(_CONFIG_.videoParseList[index]);
                    vipList.find("li").removeClass("selected");
                    $(this).addClass("selected");
                    hideAll();
                });

                // 跳转播放点击事件
                vipList.on('click', '.tc-li', function(e) {
                    e.stopPropagation();
                    const index = parseInt($(this).data("index"));
                    const parseObj = _CONFIG_.videoParseList[index];
                    if (parseObj) {
                        const url = parseObj.url + window.location.href;
                        GM_openInTab(url, {active: true});
                        hideAll();
                    }
                });

                // 拖拽功能
                totalArea.on('mousedown', function(e) {
                    if (!$(e.target).closest(".vip-main").length) return;
                    if (e.which !== 1) return;

                    const startPos = { x: e.pageX, y: e.pageY };
                    const boxPos = {
                        x: parseInt(totalArea.css("left")) || 20,
                        y: parseInt(totalArea.css("top")) || ($(window).height()/2 - 100)
                    };

                    totalArea.css("cursor", "grabbing");

                    const onMouseMove = (e) => {
                        e.preventDefault();
                        const dx = e.pageX - startPos.x;
                        const dy = e.pageY - startPos.y;
                        let newX = boxPos.x + dx;
                        let newY = boxPos.y + dy;

                        const maxX = $(window).width() - 450;
                        const maxY = $(window).height() - 300;
                        newX = Math.max(0, Math.min(newX, maxX));
                        newY = Math.max(0, Math.min(newY, maxY));

                        totalArea.css({ left: newX, top: newY, transform: 'none' });
                    };

                    const onMouseUp = () => {
                        $(document).off("mousemove", onMouseMove);
                        $(document).off("mouseup", onMouseUp);
                        totalArea.css("cursor", "default");
                    };

                    $(document).on("mousemove", onMouseMove);
                    $(document).on("mouseup", onMouseUp);
                });

                resolve();
            });
        }

        // 使用0.2版本的播放器替换逻辑
        showPlayerWindow(videoObj) {
            util.findTargetEle(_CONFIG_.currentPlayerNode.container)
                .then((container) => {
                    const type = videoObj.type;
                    let url = videoObj.url + window.location.href;
                    if (type.includes("1")) {
                        $(container).empty();
                        util.reomveVideo();
                        let iframeDivCss = "width:100%;height:100%;z-index:999999;";
                        if (_CONFIG_.isMobile) {
                            iframeDivCss = "width:100%;height:450px;z-index:999999;";
                        }
                        if (_CONFIG_.isMobile && window.location.href.indexOf("iqiyi.com") !== -1) {
                            iframeDivCss = "width:100%;height:450px;z-index:999999;margin-top:-56.25%;";
                        }
                        try {
                            if (location.host.indexOf("youku.com") !== -1) {
                                const youkuSelectors = [
                                    "#youku-dashboard > div.kui-dashboard-dashboard-panel",
                                    "#youku-dashboard > div.kui-dashboard-dashboard-background",
                                    "#youku-dashboard > div.kui-dashboard-bar-container",
                                    "#youku-dashboard > div.kui-dashboard-timer-container"
                                ];
                                // 多次尝试清理,兼容异步渲染/延迟挂载
                                let attempts = 0;
                                const maxAttempts = 3;
                                const tid = setInterval(() => {
                                    attempts++;
                                    youkuSelectors.forEach(sel => {
                                        document.querySelectorAll(sel).forEach(n => n.remove());
                                    });
                                    if (attempts >= maxAttempts) clearInterval(tid);
                                }, 500);
                            }
                        } catch (e) {
                            console.warn("Youku cleanup error:", e);
                        }
                        $(container).append(`<div style="${iframeDivCss}"><iframe id="iframe-player-4a5b6c" src="${url}" style="border:none;" allowfullscreen="true" width="100%" height="100%"></iframe></div>`);
                    }
                });
        }

        // 使用0.2版本的URL变化处理逻辑
        postHandle() {
            let oldHref = window.location.href;
            let interval = setInterval(() => {
                let newHref = window.location.href;
                if (oldHref !== newHref) {
                    oldHref = newHref;
                    if (!!GM_getValue(_CONFIG_.flag, null)){
                        clearInterval(interval);
                        window.location.reload();
                    }
                }
            }, 1000);
            return Promise.resolve();
        }
    }

    new BaseConsumer().parse();
})();