// ==UserScript==
// @name 江湖百宝囊丨视频解析
// @namespace http://tampermonkey.net/
// @version 2.1.0
// @author Shaw
// @license MIT
// @icon 
// @description 提供国内常用视频网站vip解析、付费点播服务,仅供技术学习、交流研究使用,勿作他用。『条件允许的情况下,请支持正版』
// @run-at document-end
// @require https://cdn.jsdelivr.net/npm/vue@2.6.14/dist/vue.min.js
// @match https://v.qq.com/x/c*
// @match https://www.iqiyi.com/v*
// @match https://v.youku.com/v*
// @match https://www.mgtv.com/b*
// @match https://tv.sohu.com/v*
// @match https://www.bilibili.com/bangumi*
// ==/UserScript==
(function() {
"use strict";
let vList = [
"https://v.qq.com/x",
"https://www.iqiyi.com/v",
"https://v.youku.com/v",
"https://www.mgtv.com/b",
"https://tv.sohu.com/v",
"https://www.bilibili.com/bangumi",
];
let xList = [
"https://vip.parwix.com:4433/player/?url=",
"https://www.h8jx.com/jiexi.php?url=",
"https://z1.m1907.cn/?jx=",
"https://jx.aidouer.net/?url=",
"https://api.qianqi.net/vip/?url=",
"https://www.gai4.com/?url=",
"https://www.ckmov.vip/api.php?url=",
"https://ckmov.ccyjjd.com/ckmov/?url=",
"https://api.jiexi.la/?url=",
"https://lecurl.cn/?url=",
"https://vip.laobandq.com/jiexi.php?url=",
"https://api.leduotv.com/wp-api/ifr.php?isDp=1&vid=",
"https://www.mtosz.com/m3u8.php?url=",
"https://jx.m3u8.tv/jiexi/?url=",
"https://www.ckmov.com/?url=",
"https://www.nxflv.com/?url=",
"https://okjx.cc/?url=",
"https://www.playm3u8.cn/jiexi.php?url=",
"https://www.pangujiexi.cc/jiexi.php?url=",
"https://qimihe.com/?url=",
"https://jx.blbo.cc:4433/?url=",
"https://jx.rdhk.net/?v=",
"https://jx.ap2p.cn/?url=",
"https://jsap.attakids.com/?url=",
"https://jx.vodjx.top/vip/?url=",
"https://jx.dj6u.com/?url=",
"https://jx.ivito.cn/?url=",
"https://jx.xmflv.com/?url=",
"https://www.kpezp.cn/jlexi.php?url=",
"https://sb.5gseo.net/?url=",
"https://jx.yparse.com/index.php?url=",
"https://go.yh0523.cn/y.cy?url=",
"https://www.1717yun.com/jx/ty.php?url=",
"https://jx.4kdv.com/?url=",
"https://www.8090g.cn/?url="
];
let vipJX = getVal("vipJX", xList[0]);
let { href, width = "90px" } = location;
let css =
`
.s-list,
.s-list * {
margin: 0;
padding: 0;
font: 14px Arial, Helvetica, sans-serif !important;
text-decoration: none !important;
list-style: none !important;
box-sizing: content-box !important;
-webkit-font-smoothing: subpixel-antialiased !important;
}
.s-list {
position: fixed;
left: 0;
top: 50%;
z-index: 999999;
width: ${width};
border-radius: 0 4px 4px 0;
transform: translate3d(-100%, -50%, 0);
transition: 0.3s;
background: #272931;
}
.s-list:hover {
transform: translate3d(0, -50%, 0);
}
.s-item {
position: relative;
display: flex;
justify-content: center;
align-items: center;
height: 36px;
color: #09aaff !important;
}
.s-item:nth-of-type(n + 2)::before {
content: "";
position: absolute;
left: 0;
right: 0;
top: 0;
border-top: 1px solid #1d212a;
}
.s-title {
position: absolute;
right: 0;
top: 50%;
width: 1.5em;
padding: 5px 2px;
text-align: center;
color: #fff;
cursor: auto;
user-select: none;
border-radius: 0 4px 4px 0;
transform: translate3d(100%, -50%, 0);
background: #fc4273;
}
.s-dot::after {
content: "";
position: absolute;
right: 0;
top: 50%;
border: 6px solid transparent;
border-right-color: #0e6;
transform: translate3d(0, -50%, 0);
}
.s-tips {
font-size: 13px !important;
color: #e9b15e !important;
user-select: none;
}
.s-box {
position: relative;
overflow: hidden;
border-bottom-right-radius: 4px;
background: #272931;
}
.s-ul {
max-height: 72px;
margin-right: -2em;
overflow: auto;
cursor: pointer;
}
.s-li {
position: relative;
display: flex;
justify-content: center;
align-items: center;
width: ${width};
height: 36px;
color: #09aaff !important;
}
.s-box::before,
.s-li::before {
content: "";
position: absolute;
left: 0;
right: 0;
top: 0;
border-top: 1px solid #1d212a;
}
`;
// ------ 本地存储封装 ------
function setVal(key, val, storage = localStorage) {
if (typeof val !== "undefined" && typeof storage === "object" && typeof storage.setItem === "function") {
storage.setItem(key, JSON.stringify(val));
}
}
function getVal(key, def = undefined, storage = localStorage) {
if (typeof storage === "object" && typeof storage.getItem === "function") {
let res = JSON.parse(storage.getItem(key));
return res !== null ? res : def;
}
}
function delVal(key, storage = localStorage) {
if (typeof storage === "object" && typeof storage.removeItem === "function") {
if (typeof key !== "string" && typeof storage.clear === "function") {
return storage.clear();
}
storage.removeItem(key);
}
}
// ------ VIP视频解析 ------
if (vList.some((item) => href.startsWith(item))) {
let vm = {};
let oDiv = document.createElement("div");
document.querySelector("body").appendChild(oDiv);
let oStyle = document.createElement("style");
document.querySelector("body").appendChild(oStyle).innerHTML = css;
/* global Vue */
new Vue({
el: oDiv,
template:
`
<div class="s-list">
<div class="s-title">解析</div>
<a class="s-item" :href="vipJX" @mouseover="handleClick(currIndex)">本窗观看</a>
<a class="s-item" :href="vipJX" target="_blank" @mouseover="handleClick(currIndex)">新窗观看</a>
<template v-if="xList.length > 0">
<div class="s-item s-tips">{{xList.length + "条可选线路"}}</div>
<div class="s-box">
<ul class="s-ul" ref="ul">
<li class="s-li" :class="{'s-dot': currIndex === i}" v-for="(item, i) in xList" :key="i" @click="handleClick(i)">{{handleText(i)}}</li>
</ul>
</div>
</template>
</div>
`,
data() {
vm = this;
return {
vipJX,
xList,
currIndex: xList.indexOf(vipJX) > -1 ? xList.indexOf(vipJX) : 0
};
},
methods: {
handleClick(index) {
href = location.href.split("?")[0];
// 解决youku点击添加参数bug
href.startsWith("https://v.youku.com/") && (href = location.href);
setVal("vipJX", xList[vm.currIndex = index]);
vm.vipJX = xList[index] + href;
},
handleText(index) {
return `线路${String(index + 1).padStart(2, 0)}`;
}
},
mounted() {
let [li] = vm.$refs.ul.children;
vm.$refs.ul.scrollTop = li.clientHeight * vm.currIndex;
}
});
}
})();