影视vip通行证

支持:腾讯、爱奇艺、优酷、芒果、pptv、乐视、bilibili等其它网站

目前為 2025-09-04 提交的版本,檢視 最新版本

// ==UserScript==
// @name              影视vip通行证
// @name:zh-CN        影视vip通行证
// @namespace         http://tampermonkey.net/
// @version           3.11
// @description       支持:腾讯、爱奇艺、优酷、芒果、pptv、乐视、bilibili等其它网站
// @description:zh-CN 支持:腾讯、爱奇艺、优酷、芒果、pptv、乐视、bilibili等其它网站
// @icon              
// @author            https://pro.gleeze.com/article/46
// @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           *://v.youku.com/v_*
// @include           *://*.youku.com/v_*
// @include           *://*.youku.com/video*
// @include           *://*.youku.com/*?vid=*
// @include           *://*.mgtv.com/b/*
// @include           *://*.tudou.com/listplay/*
// @include           *://*.tudou.com/programs/view/*
// @include           *://*.tudou.com/albumplay/*
// @include           *://film.sohu.com/album/*
// @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/page/*
// @include           *://m.v.qq.com/x/cover/*
// @include           *://m.v.qq.com/*
// @include           *://m.iqiyi.com/*
// @include           *://m.iqiyi.com/kszt/*
// @include           *://m.youku.com/video/*
// @include           *://m.mgtv.com/b/*
// @include           *://m.tv.sohu.com/v/*
// @include           *://m.film.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://update.gf.qytechs.cn/scripts/494892/1376206/jquery-351.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(`Element "${targetContainer}" not found after ${maxTryTime / 2} seconds.`));
                }
            }, 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),
        flag: "flag_vip",
        autoPlayerKey: "auto_player_key" + window.location.host,
        autoPlayerVal: "auto_player_value_" + window.location.host,
        videoParseList: [
            {"name":"IK","type": "1,3", "url":"https://pl.aszzys.com/player/ec.php?code=ikm3u8&if=1&url="},
            {"name":"M1907", "type": "1,3", "url":"https://im1907.top/?jx="},
            {"name":"2s0", "type": "1,3", "url":"https://jx.2s0.cn/player/?url="},
            {"name":"虾米", "type": "1,3", "url":"https://jx.xmflv.com/?url="},
            {"name":"playerjy", "type": "1,3", "url": "https://jx.playerjy.com/?url="},
            {"name":"ckplayer", "type": "1,3", "url": "https://www.ckplayer.vip/jiexi/?url="},
            {"name":"IK9", "type": "1,3", "url":"https://yparse.ik9.cc/index.php?url="},
            {"name":"973解析", "type": "1,3", "url":"https://jx.973973.xyz/?url="},
            {"name":"789解析", "type": "1,3", "url":"https://jiexi.789jiexi.com/?url="}, 
            {"name": "playm3u8", "type": "1,3", "url": "https://www.playm3u8.cn/jiexi.php?url="},
 
           {"name": "!后面重复", "type": "1,3", "url": ""},
 
            {"name": "芒果", "type": "1,3", "url": "https://jx.m3u8.tv/jiexi/?url="},
            {"name": "夜幕", "type": "1,3", "url": "https://www.yemu.xyz/?url="},
            {"name": "盘古", "type": "1,3", "url": "https://www.pangujiexi.com/jiexi/?url="},
            {"name": "8090", "type": "1,3", "url": "https://www.8090g.cn/?url="},
            {"name": "芒果TV1", "type": "1,3", "url": "https://video.isyour.love/player/getplayer?url="},
            {"name":"FF","type": "1,3", "url":"https://pl.aszzys.com/player/ec.php?code=ffm3u8&if=1&url="},
            {"name":"HM","type": "1,3", "url":"https://pl.aszzys.com/player/ec.php?code=heimuer&if=1&url="},
            {"name":"LZ","type": "1,3", "url":"https://pl.aszzys.com/player/ec.php?code=lzm3u8&if=1&url="},
            {"name":"咸鱼TV", "type": "1,3", "url":"https://jx.xymp4.cc/?url="},
            {"name": "七七云解析", "type": "1,3", "url": "https://jx.77flv.cc/?url="},
            {"name":"七哥", "type": "1,3", "url":"https://jx.nnxv.cn/tv.php?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: "#video", name: "Default", displayNodes: ["#playerPopup", "#vipCoversBox" ,"#video > div.covers_cloudCover__ILy8R.covers_pcw__jFO8q","div[class^=qy-header-login-pop]"]},
            {
                host: "m.iqiyi.com",
                container: ".m-video-player-wrap,iqpdiv.iqp-player",
                name: "Default",
                displayNodes: ["div.m-iqyGuide-layer", "a[down-app-android-url]", "[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: "#player,.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((container) => this.preHandle(container))
                    .then((container) => this.generateElement(container))
                    .then((container) => this.bindEvent(container))
                    .then((container) => this.autoPlay(container))
                    .then((container) => this.postHandle(container))
                    .catch(error => {
                        console.error("SuperVip script initialization failed:", error);
                    });
            }
        }

        preHandle(container) {
            _CONFIG_.currentPlayerNode.displayNodes.forEach((item, index) => {
                util.findTargetEle(item)
                    .then((obj) => obj.style.display = 'none')
                    .catch(e => console.warn("Element to hide not found:", item));
            });
            return Promise.resolve(container);
        }

        generateElement(container) {
            GM_addStyle(`
                        #${_CONFIG_.vipBoxId} {cursor:pointer; position:fixed; top:120px; left:0px; z-index:99999999; text-align:left; font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;}
                        #${_CONFIG_.vipBoxId} .control-button {
                            width: 38px; height: 38px;
                            background: linear-gradient(145deg, #2e3138, #26292e);
                            box-shadow: 4px 4px 8px #202226, -4px -4px 8px #343840;
                            border-radius: 10px;
                            margin: 10px 0;
                            display: flex;
                            align-items: center;
                            justify-content: center;
                            transition: all 0.2s ease-in-out;
                        }
                        #${_CONFIG_.vipBoxId} .control-button:hover {
                            transform: scale(1.05);
                            box-shadow: 6px 6px 12px #202226, -6px -6px 12px #343840;
                        }
                        #${_CONFIG_.vipBoxId} .control-button .vip-text {
                            font-weight: bold;
                            font-size: 16px;
                            color: #8c9099;
                        }
                        #${_CONFIG_.vipBoxId} .control-button .vip-text-v { color: #f44336; }
                        #${_CONFIG_.vipBoxId} .control-button .vip-text-p { color: #ffeb3b; }

                        #${_CONFIG_.vipBoxId} .power-icon { fill: #8c9099; width: 22px; height: 22px; transition: fill 0.2s ease-in-out;}
                        #${_CONFIG_.vipBoxId} .power-icon.on { fill: #4CAF50; }

                        #${_CONFIG_.vipBoxId} .vip_list {
                            display:none; position:absolute; border-radius:10px; left:48px; top:0;
                            background-color: #2a2d33;
                            border: 1px solid #3c414a;
                            padding: 10px;
                            width:380px; max-height:400px; overflow-y:auto;
                            box-shadow: 10px 10px 20px #202226, -10px -10px 20px #343840;
                            opacity: 0;
                            transform: translateX(-10px);
                            transition: opacity 0.2s ease-out, transform 0.2s ease-out;
                        }
                        #${_CONFIG_.vipBoxId} .vip_icon.active .vip_list {
                           display: block;
                           opacity: 1;
                           transform: translateX(0);
                        }

                        #${_CONFIG_.vipBoxId} .vip_list li{
                            font-size:12px; color:#DCDCDC; text-align:center;
                            width:calc(25% - 14px); line-height:24px; float:left;
                            border:1px solid #4a4f59; padding:0 4px; margin:4px 2px;
                            border-radius:5px;
                            overflow:hidden; white-space: nowrap; text-overflow: ellipsis;
                            transition: all 0.2s ease-in-out;
                            background: #2a2d33;
                        }
                        #${_CONFIG_.vipBoxId} .vip_list li:hover{color:#fff; border-color:#00aaff; background: #3c414a;}
                        #${_CONFIG_.vipBoxId} .vip_list ul{padding-left: 10px; margin-block: 0.5em;}
                        #${_CONFIG_.vipBoxId} .vip_list::-webkit-scrollbar{width:5px; height:1px;}
                        #${_CONFIG_.vipBoxId} .vip_list::-webkit-scrollbar-thumb{background:#4a4f59; border-radius:5px;}
                        #${_CONFIG_.vipBoxId} .vip_list::-webkit-scrollbar-track{background:transparent;}
                        #${_CONFIG_.vipBoxId} li.selected{color:#fff; border-color:#00aaff; background: #007acc;}
						`);

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

            const powerIconSvg = `
                <svg class="power-icon" viewBox="0 0 24 24">
                    <path d="M16.5 3.5a1 1 0 0 1 1 1v5a1 1 0 0 1-2 0v-5a1 1 0 0 1 1-1zM12 2a10 10 0 1 1 0 20 10 10 0 0 1 0-20zm0 2a8 8 0 1 0 0 16 8 8 0 0 0 0-16z"/>
                </svg>`;

            $(container).append(`
                <div id="${_CONFIG_.vipBoxId}">
                    <div class="vip_icon">
                        <div class="control-button" title="选择解析源">
                            <span class="vip-text"><span class="vip-text-v">V</span>I<span class="vip-text-p">P</span></span>
                        </div>
                        <div class="vip_list">
                            <div>
                                <h3 style="color:#00aaff; font-weight: bold; font-size: 16px; padding:5px 0px; margin:0;">[内嵌播放]</h3>
                                <ul>
                                    ${type_1_str}
                                    <div style="clear:both;"></div>
                                </ul>
                            </div>
                            <div>
                                <h3 style="color:#00aaff; font-weight: bold; font-size: 16px; padding:5px 0px; margin:0;">[弹窗播放]</h3>
                                <ul>
                                    ${type_3_str}
                                    <div style="clear:both;"></div>
                                </ul>
                            </div>
                             <div style="text-align:left;color:#999;font-size:10px;padding:0px 10px;margin-top:10px;">
                                <b>提示:</b>右键点击悬浮窗可拖动位置。
                            </div>
                        </div>
                    </div>
                    <div class="control-button" id="vip_auto" title="开启/关闭自动解析">${powerIconSvg}</div>
                </div>`);

            // Set initial state for power icon
            if (!!GM_getValue(_CONFIG_.autoPlayerKey, null)) {
                $(`#${_CONFIG_.vipBoxId} #vip_auto .power-icon`).addClass('on');
            }

            return Promise.resolve(container);
        }

        bindEvent(container) {
            const vipBox = $(`#${_CONFIG_.vipBoxId}`);
            const vipIcon = vipBox.find(".vip_icon");

            // ########## FIX START ##########
            // 优化悬浮菜单交互逻辑
            let hideTimeout;
            if (_CONFIG_.isMobile) {
                vipIcon.on("click", () => vipIcon.toggleClass('active'));
            } else {
                vipIcon.on("mouseenter", () => {
                    clearTimeout(hideTimeout);
                    vipIcon.addClass('active');
                });
                vipIcon.on("mouseleave", () => {
                    hideTimeout = setTimeout(() => {
                        vipIcon.removeClass('active');
                    }, 200); // 延迟200毫秒关闭,给鼠标移动到列表上的时间
                });
            }
            // ########## FIX END ##########


            let _this = this;
            vipBox.find(".vip_list .nq-li").each((liIndex, item) => {
                item.addEventListener("click", () => {
                    const index = parseInt($(item).attr("data-index"));
                    GM_setValue(_CONFIG_.autoPlayerVal, index);
                    GM_setValue(_CONFIG_.flag, "true");
                    _this.showPlayerWindow(_CONFIG_.videoParseList[index]);
                    vipBox.find(".vip_list li").removeClass("selected");
                    $(item).addClass("selected");
                });
            });
            vipBox.find(".vip_list .tc-li").each((liIndex, item) => {
                item.addEventListener("click", () => {
                    const index = parseInt($(item).attr("data-index"));
                    const videoObj = _CONFIG_.videoParseList[index];
                    let url = videoObj.url + window.location.href;
                    GM_openInTab(url, {active: true, insert: true, setParent: true});
                });
            });

            //右键移动位置
            vipBox.on('contextmenu', e => e.preventDefault());
            vipBox.mousedown(function (e) {
                if (e.which !== 3) {
                    return;
                }
                vipBox.css("cursor", "move");
                const positionDiv = $(this).offset();
                let distenceX = e.pageX - positionDiv.left;
                let distenceY = e.pageY - positionDiv.top;

                $(document).mousemove(function (e) {
                    let x = e.pageX - distenceX;
                    let y = e.pageY - distenceY;
                    const windowWidth = $(window).width();
                    const windowHeight = $(window).height();

                    if (x < 0) x = 0;
                    else if (x > windowWidth - vipBox.outerWidth(true)) x = windowWidth - vipBox.outerWidth(true);
                    if (y < 0) y = 0;
                    else if (y > windowHeight - vipBox.outerHeight(true)) y = windowHeight - vipBox.outerHeight(true);

                    vipBox.css("left", x);
                    vipBox.css("top", y);
                });
                $(document).mouseup(function () {
                    $(document).off('mousemove');
                    vipBox.css("cursor", "pointer");
                });
            });
            return Promise.resolve(container);
        }

        autoPlay(container) {
            const vipBox = $(`#${_CONFIG_.vipBoxId}`);
            vipBox.find("#vip_auto").on("click", function () {
                const icon = $(this).find('.power-icon');
                if (!!GM_getValue(_CONFIG_.autoPlayerKey, null)) {
                    GM_setValue(_CONFIG_.autoPlayerKey, null);
                    icon.removeClass('on');
                } else {
                    GM_setValue(_CONFIG_.autoPlayerKey, "true");
                    icon.addClass('on');
                }
                setTimeout(() => window.location.reload(), 200);
            });

            if (!!GM_getValue(_CONFIG_.autoPlayerKey, null)) {
                this.selectPlayer(container);
            }
            return Promise.resolve(container);
        }

        selectPlayer(container) {
            let index = GM_getValue(_CONFIG_.autoPlayerVal, 0); // Default to first one
            let autoObj = _CONFIG_.videoParseList[index];
            if (!autoObj || !autoObj.type.includes("1")) { // Fallback if saved index is invalid or not embeddable
                const firstEmbeddable = _CONFIG_.videoParseList.find(p => p.type.includes("1"));
                if (!firstEmbeddable) {
                    console.error("No embeddable (type 1) video source found for autoplay.");
                    return;
                }
                autoObj = firstEmbeddable;
                index = _CONFIG_.videoParseList.indexOf(firstEmbeddable);
                GM_setValue(_CONFIG_.autoPlayerVal, index);
            }

            let _th = this;
            setTimeout(function () {
                _th.showPlayerWindow(autoObj);
                const vipBox = $(`#${_CONFIG_.vipBoxId}`);
                vipBox.find(`.vip_list .nq-li[data-index=${index}]`).addClass("selected");
            }, 1500);
        }

        showPlayerWindow(videoObj) {
            util.findTargetEle(_CONFIG_.currentPlayerNode.container)
                .then((container) => {
                    let url = videoObj.url + window.location.href;
                    $(container).empty();
                    util.reomveVideo();
                    let iframeDivCss = "width:100%;height:100%;z-index:9999999;";
                    if (_CONFIG_.isMobile) {
                        iframeDivCss = "width:100%;height:450px;z-index:9999999;";
                    }
                    if (_CONFIG_.isMobile && window.location.href.indexOf("iqiyi.com") !== -1) {
                        iframeDivCss = "width:100%;height:450px;z-index:9999999;margin-top:-56.25%;";
                    }
                    $(container).append(`<div style="${iframeDivCss}"><iframe id="iframe-player-4a5b6c" src="${url}" style="border:none;" allowfullscreen="true" width="100%" height="100%"></iframe></div>`);
                })
                .catch(error => {
                    alert(`播放器容器 "${_CONFIG_.currentPlayerNode.container}" 未找到,可能是页面加载问题或广告拦截插件干扰。请尝试关闭广告拦截并刷新页面。`);
                    console.error(error);
                });
        }

        postHandle(container) {
            if (!!GM_getValue(_CONFIG_.autoPlayerKey, null)) {
                util.urlChangeReload();
            } else {
                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);
            }
        }

    }

    class DefaultConsumer extends BaseConsumer {}

    return {
        start: () => {
            GM_setValue(_CONFIG_.flag, null);
            let mallCase = 'Default';
            let playerNode = _CONFIG_.playerContainers.filter(value => value.host === window.location.host);
            if (playerNode === null || playerNode.length <= 0) {
                console.warn(window.location.host + "该网站暂不支持。");
                return;
            }
            _CONFIG_.currentPlayerNode = playerNode[0];
            mallCase = _CONFIG_.currentPlayerNode.name;
            const targetConsumer = eval(`new ${mallCase}Consumer`);
            targetConsumer.parse();
        }
    }

})();

(function () {
    'use strict';
    // Delayed start to ensure page is fully loaded, especially with ad blockers altering the DOM.
    $(document).ready(function() {
        setTimeout(superVip.start, 1000);
    });
})();

QingJ © 2025

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