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

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

  1. // ==UserScript==
  2. // @name 🔥🔥全网VIP视频免费解析,并去广告🔥🔥
  3. // @namespace https://www.softrr.cn/
  4. // @version 2.2.5
  5. // @author hackhase
  6. // @description 全网VIP视频免费破解,支持:腾讯、爱奇艺、优酷、芒果、pptv、乐视等其它网站。
  7. // @license MIT
  8. // @icon https://v.qq.com/favicon.ico#/
  9. // @match *://v.qq.com/*
  10. // @match *://*.iqiyi.com/*
  11. // @match *://*.iq.com/*
  12. // @match *://*.youku.com/*
  13. // @match *://*.tudou.com/*
  14. // @match *://film.sohu.com/*
  15. // @match *://*.bilibili.com/*
  16. // @match *://*.pptv.com/*
  17. // @match *://tv.sohu.com/*
  18. // @match *://*.mgtv.com/*
  19. // @match *://*.1905.com/*
  20. // @match *://*.le.com/*
  21. // @require https://cdn.jsdelivr.net/npm/vue@3.3.11/dist/vue.global.prod.js
  22. // @connect www.softrr.cn
  23. // @connect api.softrr.cn
  24. // @grant GM_addStyle
  25. // @grant GM_xmlhttpRequest
  26. // @grant unsafeWindow
  27. // ==/UserScript==
  28.  
  29. (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} ");
  30.  
  31. (function (vue) {
  32. 'use strict';
  33.  
  34. var _GM_xmlhttpRequest = /* @__PURE__ */ (() => typeof GM_xmlhttpRequest != "undefined" ? GM_xmlhttpRequest : void 0)();
  35. const _export_sfc = (sfc, props) => {
  36. const target = sfc.__vccOpts || sfc;
  37. for (const [key, val] of props) {
  38. target[key] = val;
  39. }
  40. return target;
  41. };
  42. const _withScopeId$1 = (n) => (vue.pushScopeId("data-v-c870d347"), n = n(), vue.popScopeId(), n);
  43. const _hoisted_1$1 = { class: "modal" };
  44. const _hoisted_2$1 = { class: "header" };
  45. const _hoisted_3$1 = { class: "content" };
  46. const _hoisted_4$1 = { class: "produce" };
  47. const _hoisted_5$1 = /* @__PURE__ */ _withScopeId$1(() => /* @__PURE__ */ vue.createElementVNode("p", null, "1、扫描右侧公众号,点击关注!", -1));
  48. const _hoisted_6$1 = /* @__PURE__ */ _withScopeId$1(() => /* @__PURE__ */ vue.createElementVNode("p", null, "2、在软件爬取者后台回复:验证码", -1));
  49. const _hoisted_7 = /* @__PURE__ */ _withScopeId$1(() => /* @__PURE__ */ vue.createElementVNode("p", null, "3、在下方输入框输入获取的验证码后回车", -1));
  50. const _hoisted_8 = /* @__PURE__ */ _withScopeId$1(() => /* @__PURE__ */ vue.createElementVNode("div", { class: "img" }, [
  51. /* @__PURE__ */ vue.createElementVNode("img", {
  52. src: "",
  53. alt: ""
  54. })
  55. ], -1));
  56. const _sfc_main$1 = {
  57. __name: "Model",
  58. props: {
  59. title: {
  60. type: String,
  61. required: true
  62. },
  63. code: {
  64. type: Number || String
  65. }
  66. },
  67. setup(__props, { expose: __expose }) {
  68. const props = __props;
  69. const visible = vue.ref(false);
  70. const openModal = () => {
  71. visible.value = true;
  72. };
  73. const closeModal = () => {
  74. visible.value = false;
  75. };
  76. __expose({
  77. visible,
  78. openModal,
  79. closeModal
  80. });
  81. const codeValue = vue.ref();
  82. const enterCode = () => {
  83. if (codeValue.value == props.code) {
  84. localStorage.setItem("code", codeValue.value);
  85. visible.value = false;
  86. alert("验证成功,请再次点击解析!");
  87. codeValue.value = "";
  88. } else {
  89. alert("验证码错误,请重新输入!");
  90. codeValue.value = "";
  91. }
  92. };
  93. return (_ctx, _cache) => {
  94. return vue.withDirectives((vue.openBlock(), vue.createElementBlock("div", {
  95. class: "modal-wrapper",
  96. onClick: vue.withModifiers(closeModal, ["self"])
  97. }, [
  98. vue.createElementVNode("div", _hoisted_1$1, [
  99. vue.createElementVNode("div", _hoisted_2$1, [
  100. vue.createElementVNode("h2", null, vue.toDisplayString(__props.title), 1),
  101. vue.createElementVNode("button", { onClick: closeModal }, "X")
  102. ]),
  103. vue.createElementVNode("div", _hoisted_3$1, [
  104. vue.createElementVNode("div", _hoisted_4$1, [
  105. _hoisted_5$1,
  106. _hoisted_6$1,
  107. _hoisted_7,
  108. vue.withDirectives(vue.createElementVNode("input", {
  109. class: "ipt",
  110. type: "text",
  111. "onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => codeValue.value = $event),
  112. onKeydown: vue.withKeys(enterCode, ["enter"]),
  113. placeholder: "请输入验证码后按回车"
  114. }, null, 544), [
  115. [vue.vModelText, codeValue.value]
  116. ])
  117. ]),
  118. _hoisted_8
  119. ])
  120. ])
  121. ], 512)), [
  122. [vue.vShow, visible.value]
  123. ]);
  124. };
  125. }
  126. };
  127. const Model = /* @__PURE__ */ _export_sfc(_sfc_main$1, [["__scopeId", "data-v-c870d347"]]);
  128. const getCode = () => {
  129. return new Promise(function(resolve, reject) {
  130. _GM_xmlhttpRequest({
  131. method: "GET",
  132. url: `https://api.softrr.cn/api/verification?id=1`,
  133. headers: {
  134. Referer: "https://api.softrr.cn/",
  135. "User-Agent": "Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/114.0.5735.289 Safari/537.36"
  136. },
  137. onload: function(res) {
  138. resolve(JSON.parse(res.response).code);
  139. },
  140. onerror: function(error) {
  141. console.log(error);
  142. }
  143. });
  144. });
  145. };
  146. const _withScopeId = (n) => (vue.pushScopeId("data-v-8143225a"), n = n(), vue.popScopeId(), n);
  147. const _hoisted_1 = { class: "copy" };
  148. const _hoisted_2 = /* @__PURE__ */ _withScopeId(() => /* @__PURE__ */ vue.createElementVNode("br", null, null, -1));
  149. const _hoisted_3 = ["value"];
  150. const _hoisted_4 = /* @__PURE__ */ _withScopeId(() => /* @__PURE__ */ vue.createElementVNode("option", { value: "in" }, "站内", -1));
  151. const _hoisted_5 = /* @__PURE__ */ _withScopeId(() => /* @__PURE__ */ vue.createElementVNode("option", { value: "out" }, "站外", -1));
  152. const _hoisted_6 = [
  153. _hoisted_4,
  154. _hoisted_5
  155. ];
  156. const _sfc_main = {
  157. __name: "App",
  158. setup(__props) {
  159. const lineValue = vue.ref("https://jx.xmflv.com?url=");
  160. const lineList = [
  161. {
  162. line: "线路1",
  163. name: "综合",
  164. type: "1,3",
  165. url: "https://www.ckplayer.vip/jiexi?url="
  166. },
  167. // {
  168. // line: '线路2',
  169. // name: 'CK',
  170. // type: '1,3',
  171. // url: 'https://jx.jsonplayer.com/player?url=',
  172. // },
  173. // {
  174. // line: '线路3',
  175. // name: 'YT',
  176. // type: '1,3',
  177. // url: 'https://jx.yangtu.top?url=',
  178. // },
  179. {
  180. line: "线路4",
  181. name: "Player-JY",
  182. type: "1,3",
  183. url: "https://jx.playerjy.com?url="
  184. },
  185. {
  186. line: "线路5",
  187. name: "yparse",
  188. type: "1,2",
  189. url: "https://jx.yparse.com/index.php?url="
  190. },
  191. {
  192. line: "线路6",
  193. name: "8090",
  194. type: "1,3",
  195. url: "https://www.8090g.cn?url="
  196. },
  197. // {
  198. // line: '线路7',
  199. // name: '剖元',
  200. // type: '1,3',
  201. // url: 'https://www.pouyun.com?url=',
  202. // },
  203. {
  204. line: "线路8",
  205. name: "虾米",
  206. type: "1,3",
  207. url: "https://jx.xmflv.com?url="
  208. },
  209. {
  210. line: "线路9",
  211. name: "全民",
  212. type: "1,3",
  213. url: "https://43.240.74.102:4433?url="
  214. },
  215. {
  216. line: "线路10",
  217. name: "爱豆",
  218. type: "1,3",
  219. url: "https://jx.aidouer.net?url="
  220. },
  221. {
  222. line: "线路11",
  223. name: "夜幕",
  224. type: "1,3",
  225. url: "https://www.yemu.xyz?url="
  226. },
  227. {
  228. line: "线路12",
  229. name: "m1907",
  230. type: "1,2",
  231. url: "https://im1907.top?jx="
  232. },
  233. {
  234. line: "线路13",
  235. name: "M3U8TV",
  236. type: "1,3",
  237. url: "https://jx.m3u8.tv/jiexi?url="
  238. },
  239. { line: "线路14", name: "冰豆", type: "1,3", url: "https://bd.jx.cn?url=" },
  240. {
  241. line: "线路15",
  242. name: "playm3u8",
  243. type: "1,3",
  244. url: "https://www.playm3u8.cn/jiexi.php?url="
  245. }
  246. ];
  247. const code = vue.ref();
  248. const showLine = vue.ref(false);
  249. const inLine = vue.ref("out");
  250. const url = window.location.href;
  251. const model = vue.ref("");
  252. const onPrase = async () => {
  253. let locaCode = localStorage.getItem("code") || "";
  254. code.value = await getCode();
  255. if (locaCode == code.value) {
  256. if (inLine.value === "out") {
  257. window.open(lineValue.value + url, "_blank");
  258. } else {
  259. window.location.href = lineValue.value + url;
  260. }
  261. showLine.value = false;
  262. } else {
  263. model.value.openModal();
  264. }
  265. };
  266. const title = vue.ref("为了减少端口压力,防止滥用,采取必要的验证手段。");
  267. const parseListRef = vue.ref("");
  268. const lineRef = vue.ref("");
  269. const praseRef = vue.ref("");
  270. const addAnimate = (ani) => {
  271. ani.animate(
  272. [
  273. {
  274. width: "100px"
  275. }
  276. ],
  277. {
  278. duration: 1e3,
  279. easing: "linear",
  280. delay: 0,
  281. iterations: "Infinity",
  282. direction: "alternate",
  283. fill: "forwards"
  284. }
  285. );
  286. };
  287. const onShow = () => {
  288. showLine.value = !showLine.value;
  289. addAnimate(parseListRef.value);
  290. addAnimate(lineRef.value);
  291. addAnimate(praseRef.value);
  292. };
  293. const selectRef = vue.ref("");
  294. const btnPrase = vue.ref("");
  295. const handler = (e) => {
  296. let select = document.getElementsByClassName("btnPrase")[0];
  297. let target = e.target;
  298. console.log(showLine.value);
  299. if (target == select) {
  300. showLine.value = true;
  301. } else {
  302. showLine.value = false;
  303. }
  304. };
  305. document.addEventListener("click", handler);
  306. return (_ctx, _cache) => {
  307. return vue.openBlock(), vue.createElementBlock("div", _hoisted_1, [
  308. vue.createElementVNode("button", {
  309. onClick: vue.withModifiers(onShow, ["prevent", "stop"]),
  310. class: "btnPrase",
  311. ref_key: "btnPrase",
  312. ref: btnPrase
  313. }, [
  314. vue.createTextVNode(" 解析 "),
  315. _hoisted_2,
  316. vue.createTextVNode(" 选项 ")
  317. ], 512),
  318. vue.withDirectives(vue.createElementVNode("div", {
  319. onClick: _cache[2] || (_cache[2] = vue.withModifiers(() => {
  320. }, ["stop"])),
  321. class: "select",
  322. ref_key: "selectRef",
  323. ref: selectRef
  324. }, [
  325. vue.withDirectives(vue.createElementVNode("select", {
  326. "onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => lineValue.value = $event),
  327. class: "m-2",
  328. ref_key: "parseListRef",
  329. ref: parseListRef
  330. }, [
  331. (vue.openBlock(), vue.createElementBlock(vue.Fragment, null, vue.renderList(lineList, (item) => {
  332. return vue.createElementVNode("option", {
  333. key: item.line,
  334. value: item.url
  335. }, vue.toDisplayString(item.name), 9, _hoisted_3);
  336. }), 64))
  337. ], 512), [
  338. [vue.vModelSelect, lineValue.value]
  339. ]),
  340. vue.withDirectives(vue.createElementVNode("select", {
  341. "onUpdate:modelValue": _cache[1] || (_cache[1] = ($event) => inLine.value = $event),
  342. class: "m-3",
  343. ref_key: "lineRef",
  344. ref: lineRef
  345. }, _hoisted_6, 512), [
  346. [vue.vModelSelect, inLine.value]
  347. ]),
  348. vue.createElementVNode("button", {
  349. onClick: onPrase,
  350. class: "prase",
  351. ref_key: "praseRef",
  352. ref: praseRef
  353. }, "解析", 512),
  354. vue.createVNode(Model, {
  355. title: title.value,
  356. code: code.value,
  357. ref_key: "model",
  358. ref: model
  359. }, null, 8, ["title", "code"])
  360. ], 512), [
  361. [vue.vShow, showLine.value]
  362. ])
  363. ]);
  364. };
  365. }
  366. };
  367. const App = /* @__PURE__ */ _export_sfc(_sfc_main, [["__scopeId", "data-v-8143225a"]]);
  368. vue.createApp(App).mount(
  369. (() => {
  370. const app = document.createElement("div");
  371. document.body.append(app);
  372. return app;
  373. })()
  374. );
  375.  
  376. })(Vue);

QingJ © 2025

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