Greasy Fork is available in English.

🔥🔥全网VIP视频免费解析,并去广告🔥🔥

全网VIP视频免费破解,支持:腾讯、爱奇艺、优酷、芒果、pptv、乐视等其它网站。

// ==UserScript==
// @name         🔥🔥全网VIP视频免费解析,并去广告🔥🔥
// @namespace    https://www.softrr.cn/
// @version      2.2.4
// @author       hackhase
// @description  全网VIP视频免费破解,支持:腾讯、爱奇艺、优酷、芒果、pptv、乐视等其它网站。
// @license      MIT
// @icon         https://v.qq.com/favicon.ico#/
// @match        *://v.qq.com/*
// @match        *://*.iqiyi.com/*
// @match        *://*.iq.com/*
// @match        *://*.youku.com/*
// @match        *://*.tudou.com/*
// @match        *://film.sohu.com/*
// @match        *://*.bilibili.com/*
// @match        *://*.pptv.com/*
// @match        *://tv.sohu.com/*
// @match        *://*.mgtv.com/*
// @match        *://*.1905.com/*
// @match        *://*.le.com/*
// @require      https://cdn.jsdelivr.net/npm/vue@3.3.11/dist/vue.global.prod.js
// @connect      www.softrr.cn
// @grant        GM_addStyle
// @grant        GM_xmlhttpRequest
// @grant        unsafeWindow
// ==/UserScript==

(e=>{if(typeof GM_addStyle=="function"){GM_addStyle(e);return}const t=document.createElement("style");t.textContent=e,document.head.append(t)})(" :root{font-family:Inter,Avenir,Helvetica,Arial,sans-serif;font-size:16px;line-height:24px;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}.card{padding:2em}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.modal-wrapper[data-v-c870d347]{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:9999}.modal[data-v-c870d347]{background-color:#fff;padding:20px;border-radius:5px}.header[data-v-c870d347]{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.header h2[data-v-c870d347]{margin:0;font-size:20px;font-weight:700}.header button[data-v-c870d347]{border:none;background-color:transparent;font-size:20px;cursor:pointer}.content[data-v-c870d347]{max-height:400px;overflow:auto;font-size:16px;display:flex;justify-content:space-between}.content .produce p[data-v-c870d347]{margin-top:15px}.content .produce .ipt[data-v-c870d347]{margin-top:15px;height:30px;border-radius:5px;padding-left:10px}.content .img[data-v-c870d347]{display:flex;align-items:center;justify-content:center}.content .img img[data-v-c870d347]{width:180px}input[data-v-c870d347]::-webkit-input-placeholder{color:#aab2bd;font-size:14px;padding-left:5px}.copy[data-v-8143225a]{width:160px;position:fixed;right:10px;top:80px;color:#111;z-index:999;display:flex;flex-direction:column}.copy .btnPrase[data-v-8143225a]{width:80px;height:80px;background-color:red;color:#fff;border-radius:50%;font-size:16px}.copy .btnPrase[data-v-8143225a]:hover{background-color:#87ceeb;color:#fff}.copy .select[data-v-8143225a]{position:relative;font-size:15px}.copy .select .m-2[data-v-8143225a]{position:absolute;left:-112px;top:-77px;width:70px;height:70px;border-radius:50%;margin-top:5px;background:#594686;-webkit-appearance:none;-moz-appearance:none;appearance:none;text-align:center;text-align-last:center;color:#fff}.copy .select .m-3[data-v-8143225a]{position:absolute;left:-74px;top:0;width:70px;height:70px;border-radius:50%;margin-top:5px;background:#b39d76;-webkit-appearance:none;-moz-appearance:none;appearance:none;text-align:center;text-align-last:center;color:#fff}.copy .select .prase[data-v-8143225a]{position:absolute;left:32px;top:21px;width:70px;height:70px;border-radius:50%;margin-top:5px;background:#924a55;text-align:center;text-align-last:center;color:#fff} ");

(function (vue) {
  'use strict';

  var _GM_xmlhttpRequest = /* @__PURE__ */ (() => typeof GM_xmlhttpRequest != "undefined" ? GM_xmlhttpRequest : void 0)();
  const _export_sfc = (sfc, props) => {
    const target = sfc.__vccOpts || sfc;
    for (const [key, val] of props) {
      target[key] = val;
    }
    return target;
  };
  const _withScopeId$1 = (n) => (vue.pushScopeId("data-v-c870d347"), n = n(), vue.popScopeId(), n);
  const _hoisted_1$1 = { class: "modal" };
  const _hoisted_2$1 = { class: "header" };
  const _hoisted_3$1 = { class: "content" };
  const _hoisted_4$1 = { class: "produce" };
  const _hoisted_5$1 = /* @__PURE__ */ _withScopeId$1(() => /* @__PURE__ */ vue.createElementVNode("p", null, "1、扫描右侧公众号,点击关注!", -1));
  const _hoisted_6$1 = /* @__PURE__ */ _withScopeId$1(() => /* @__PURE__ */ vue.createElementVNode("p", null, "2、在软件爬取者后台回复:验证码", -1));
  const _hoisted_7 = /* @__PURE__ */ _withScopeId$1(() => /* @__PURE__ */ vue.createElementVNode("p", null, "3、在下方输入框输入获取的验证码后回车", -1));
  const _hoisted_8 = /* @__PURE__ */ _withScopeId$1(() => /* @__PURE__ */ vue.createElementVNode("div", { class: "img" }, [
    /* @__PURE__ */ vue.createElementVNode("img", {
      src: "",
      alt: ""
    })
  ], -1));
  const _sfc_main$1 = {
    __name: "Model",
    props: {
      title: {
        type: String,
        required: true
      },
      code: {
        type: Number || String
      }
    },
    setup(__props, { expose: __expose }) {
      const props = __props;
      const visible = vue.ref(false);
      const openModal = () => {
        visible.value = true;
      };
      const closeModal = () => {
        visible.value = false;
      };
      __expose({
        visible,
        openModal,
        closeModal
      });
      const codeValue = vue.ref();
      const enterCode = () => {
        if (codeValue.value == props.code) {
          localStorage.setItem("code", codeValue.value);
          visible.value = false;
          alert("验证成功,请再次点击解析!");
          codeValue.value = "";
        } else {
          alert("验证码错误,请重新输入!");
          codeValue.value = "";
        }
      };
      return (_ctx, _cache) => {
        return vue.withDirectives((vue.openBlock(), vue.createElementBlock("div", {
          class: "modal-wrapper",
          onClick: vue.withModifiers(closeModal, ["self"])
        }, [
          vue.createElementVNode("div", _hoisted_1$1, [
            vue.createElementVNode("div", _hoisted_2$1, [
              vue.createElementVNode("h2", null, vue.toDisplayString(__props.title), 1),
              vue.createElementVNode("button", { onClick: closeModal }, "X")
            ]),
            vue.createElementVNode("div", _hoisted_3$1, [
              vue.createElementVNode("div", _hoisted_4$1, [
                _hoisted_5$1,
                _hoisted_6$1,
                _hoisted_7,
                vue.withDirectives(vue.createElementVNode("input", {
                  class: "ipt",
                  type: "text",
                  "onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => codeValue.value = $event),
                  onKeydown: vue.withKeys(enterCode, ["enter"]),
                  placeholder: "请输入验证码后按回车"
                }, null, 544), [
                  [vue.vModelText, codeValue.value]
                ])
              ]),
              _hoisted_8
            ])
          ])
        ], 512)), [
          [vue.vShow, visible.value]
        ]);
      };
    }
  };
  const Model = /* @__PURE__ */ _export_sfc(_sfc_main$1, [["__scopeId", "data-v-c870d347"]]);
  const getCode = () => {
    return new Promise((resolve, reject) => {
      _GM_xmlhttpRequest({
        method: "GET",
        url: `https://www.softrr.cn/crawler/getCode`,
        headers: {
          Referer: "https://www.softrr.cn/",
          "User-Agent": "Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/114.0.5735.289 Safari/537.36"
        },
        onload: function(res) {
          resolve(JSON.parse(res.response).data[0].code);
        }
      });
    });
  };
  const _withScopeId = (n) => (vue.pushScopeId("data-v-8143225a"), n = n(), vue.popScopeId(), n);
  const _hoisted_1 = { class: "copy" };
  const _hoisted_2 = /* @__PURE__ */ _withScopeId(() => /* @__PURE__ */ vue.createElementVNode("br", null, null, -1));
  const _hoisted_3 = ["value"];
  const _hoisted_4 = /* @__PURE__ */ _withScopeId(() => /* @__PURE__ */ vue.createElementVNode("option", { value: "in" }, "站内", -1));
  const _hoisted_5 = /* @__PURE__ */ _withScopeId(() => /* @__PURE__ */ vue.createElementVNode("option", { value: "out" }, "站外", -1));
  const _hoisted_6 = [
    _hoisted_4,
    _hoisted_5
  ];
  const _sfc_main = {
    __name: "App",
    setup(__props) {
      const lineValue = vue.ref("https://jx.xmflv.com?url=");
      const lineList = [
        {
          line: "线路1",
          name: "综合",
          type: "1,3",
          url: "https://www.ckplayer.vip/jiexi?url="
        },
        // {
        //   line: '线路2',
        //   name: 'CK',
        //   type: '1,3',
        //   url: 'https://jx.jsonplayer.com/player?url=',
        // },
        // {
        //   line: '线路3',
        //   name: 'YT',
        //   type: '1,3',
        //   url: 'https://jx.yangtu.top?url=',
        // },
        {
          line: "线路4",
          name: "Player-JY",
          type: "1,3",
          url: "https://jx.playerjy.com?url="
        },
        {
          line: "线路5",
          name: "yparse",
          type: "1,2",
          url: "https://jx.yparse.com/index.php?url="
        },
        {
          line: "线路6",
          name: "8090",
          type: "1,3",
          url: "https://www.8090g.cn?url="
        },
        // {
        //   line: '线路7',
        //   name: '剖元',
        //   type: '1,3',
        //   url: 'https://www.pouyun.com?url=',
        // },
        {
          line: "线路8",
          name: "虾米",
          type: "1,3",
          url: "https://jx.xmflv.com?url="
        },
        {
          line: "线路9",
          name: "全民",
          type: "1,3",
          url: "https://43.240.74.102:4433?url="
        },
        {
          line: "线路10",
          name: "爱豆",
          type: "1,3",
          url: "https://jx.aidouer.net?url="
        },
        {
          line: "线路11",
          name: "夜幕",
          type: "1,3",
          url: "https://www.yemu.xyz?url="
        },
        {
          line: "线路12",
          name: "m1907",
          type: "1,2",
          url: "https://im1907.top?jx="
        },
        {
          line: "线路13",
          name: "M3U8TV",
          type: "1,3",
          url: "https://jx.m3u8.tv/jiexi?url="
        },
        { line: "线路14", name: "冰豆", type: "1,3", url: "https://bd.jx.cn?url=" },
        {
          line: "线路15",
          name: "playm3u8",
          type: "1,3",
          url: "https://www.playm3u8.cn/jiexi.php?url="
        }
      ];
      const code = vue.ref();
      const showLine = vue.ref(false);
      const inLine = vue.ref("out");
      const url = window.location.href;
      const model = vue.ref("");
      const onPrase = async () => {
        let locaCode = localStorage.getItem("code") || "";
        code.value = await getCode();
        if (locaCode == code.value) {
          if (inLine.value === "out") {
            window.open(lineValue.value + url, "_blank");
          } else {
            window.location.href = lineValue.value + url;
          }
          showLine.value = false;
        } else {
          model.value.openModal();
        }
      };
      const title = vue.ref("为了减少端口压力,防止滥用,采取必要的验证手段。");
      const parseListRef = vue.ref("");
      const lineRef = vue.ref("");
      const praseRef = vue.ref("");
      const addAnimate = (ani) => {
        ani.animate(
          [
            {
              width: "100px"
            }
          ],
          {
            duration: 1e3,
            easing: "linear",
            delay: 0,
            iterations: "Infinity",
            direction: "alternate",
            fill: "forwards"
          }
        );
      };
      const onShow = () => {
        showLine.value = !showLine.value;
        addAnimate(parseListRef.value);
        addAnimate(lineRef.value);
        addAnimate(praseRef.value);
      };
      const selectRef = vue.ref("");
      const btnPrase = vue.ref("");
      const handler = (e) => {
        let select = document.getElementsByClassName("btnPrase")[0];
        let target = e.target;
        console.log(showLine.value);
        if (target == select) {
          showLine.value = true;
        } else {
          showLine.value = false;
        }
      };
      document.addEventListener("click", handler);
      return (_ctx, _cache) => {
        return vue.openBlock(), vue.createElementBlock("div", _hoisted_1, [
          vue.createElementVNode("button", {
            onClick: vue.withModifiers(onShow, ["prevent", "stop"]),
            class: "btnPrase",
            ref_key: "btnPrase",
            ref: btnPrase
          }, [
            vue.createTextVNode(" 解析 "),
            _hoisted_2,
            vue.createTextVNode(" 选项 ")
          ], 512),
          vue.withDirectives(vue.createElementVNode("div", {
            onClick: _cache[2] || (_cache[2] = vue.withModifiers(() => {
            }, ["stop"])),
            class: "select",
            ref_key: "selectRef",
            ref: selectRef
          }, [
            vue.withDirectives(vue.createElementVNode("select", {
              "onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => lineValue.value = $event),
              class: "m-2",
              ref_key: "parseListRef",
              ref: parseListRef
            }, [
              (vue.openBlock(), vue.createElementBlock(vue.Fragment, null, vue.renderList(lineList, (item) => {
                return vue.createElementVNode("option", {
                  key: item.line,
                  value: item.url
                }, vue.toDisplayString(item.name), 9, _hoisted_3);
              }), 64))
            ], 512), [
              [vue.vModelSelect, lineValue.value]
            ]),
            vue.withDirectives(vue.createElementVNode("select", {
              "onUpdate:modelValue": _cache[1] || (_cache[1] = ($event) => inLine.value = $event),
              class: "m-3",
              ref_key: "lineRef",
              ref: lineRef
            }, _hoisted_6, 512), [
              [vue.vModelSelect, inLine.value]
            ]),
            vue.createElementVNode("button", {
              onClick: onPrase,
              class: "prase",
              ref_key: "praseRef",
              ref: praseRef
            }, "解析", 512),
            vue.createVNode(Model, {
              title: title.value,
              code: code.value,
              ref_key: "model",
              ref: model
            }, null, 8, ["title", "code"])
          ], 512), [
            [vue.vShow, showLine.value]
          ])
        ]);
      };
    }
  };
  const App = /* @__PURE__ */ _export_sfc(_sfc_main, [["__scopeId", "data-v-8143225a"]]);
  vue.createApp(App).mount(
    (() => {
      const app = document.createElement("div");
      document.body.append(app);
      return app;
    })()
  );

})(Vue);