在您安装前,Sleazy Fork 希望您知道此脚本包含可能不受欢迎的功能,也许会帮助脚本作者获利,而不能给你带来任何收益。
你只有在付费后才能使用脚本的全部功能。Sleazy Fork 未参与到支付的流程,因此无法验证您是否获得了有价值的东西,亦无法帮助您申请退款。
🔥免费无限制看所有可预览付费视频,下载视频(日限),复制播放链接,屏蔽广告
// ==UserScript== // @name 草榴短视频 // @version 1.0.0 // @updateDesc // @description 🔥免费无限制看所有可预览付费视频,下载视频(日限),复制播放链接,屏蔽广告 // @icon https://cdn.luckychajian.com/image/boy.jpeg // @namespace 草榴短视频 // @author lucky // @include */pages/hjsq* // @include *://*.dzp*.*.*/* // @include *://dzp*.*.*/* // @include *://blog.luckly-mjw.cn/* // @include *://tools.thatwind.com/* // @include *://tools.bugscaner.com/* // @require https://cdnjs.cloudflare.com/ajax/libs/jquery/3.6.0/jquery.min.js // @require https://cdnjs.cloudflare.com/ajax/libs/hls.js/1.5.8/hls.min.js // @require https://cdnjs.cloudflare.com/ajax/libs/crypto-js/4.2.0/crypto-js.min.js // @run-at document-idle // @connect cloudfront.net // @grant unsafeWindow // @grant GM_xmlhttpRequest // @grant GM_addStyle // @grant GM_getValue // @grant GM_setValue // @charset UTF-8 // @antifeature payment // @license MIT // ==/UserScript== function init($){ 'use strict'; if (location.href.includes('tools.bugscaner.com')) { util.findTargetElement('.input-group input').then(res => { const url = location.search.replace('?m3u8=', '').replace(/\s*/g, "") if (url && url.startsWith('http')) { $(res).val(url) } }) return } if (location.href.includes('tools.thatwind.com')) { GM_addStyle(`.top-ad{display: none !important;}`) util.findTargetElement('.bx--text-input__field-outer-wrapper input', 10).then(res => { $(res).val(Date.now()) res.dispatchEvent(new Event("input")) }) return } if (location.href.includes('blog.luckly-mjw.cn')) { GM_addStyle(` #m-app a,.m-p-temp-url,.m-p-cross,.m-p-input-container div:nth-of-type(1){display: none !important;} .m-p-input-container{ display: block;} .m-p-input-container input{ width: 100%;font-size: 12px;margin-bottom: 5px;} .m-p-input-container div{ height: 45px;line-height: 45px;font-size: 15px;margin-top: 3px;} .m-p-stream{line-height: normal;font-size: 12px;} `) return } const checkLogin = function(){ try{ if (superVip._CONFIG_.user.login_date != new Date().setHours(0, 0, 0,0) || md5x(superVip._CONFIG_.user.ver, 'de').code != md5x(md5x(), 'de').code) { superVip._CONFIG_.user = '' GM_setValue('jsxl_user', '') util.logouted('登录已失效,请重新登录') $("#wt-my").click() return false } return true }catch(e){ superVip._CONFIG_.user = '' GM_setValue('jsxl_user', '') util.logouted(e.message || '登录已失效,请重新登录') $("#wt-my").click() return false } } const asyncXmlhttpRequest = function (url, method, params = {}){ return new Promise((res, rej) =>{ const request = { method: method, url: url, onload: function(response) { if(response.responseText){ let result = '' try{ result = JSON.parse(response.responseText) }catch(e){ result = response.responseText } res(result) }else{ rej('请求失败_null') } }, onerror: function(e){ rej('请求失败_err') }, ontimeout: function(e){ rej('请求超时') } } if(params.data) request.data = params.data; if(params.headers) request.headers = params.headers; GM_xmlhttpRequest(request); }) } const md5x = function(s, type) { try { if (!type) { const date = new Date().setHours(0, 0, 0, 0) + ''; const day = new Date().getDate(); const code = date.substring(4, 8) * new Date().getDate() + ''; return ec.swaqbt(JSON.stringify({ date: date, code: code, day: day })); } else { const token = JSON.parse(ec.sfweccat(s)); if ((new Date(Number(token.date)).getTime() + 86400000) < Date.now()) { throw Error('md5x expire'); } if (token.day != new Date(Number(token.date)).getDate()) { throw Error('md5x err'); } const code = (new Date(Number(token.date)).setHours(0, 0, 0, 0) + '').substring(4, 8) * token.day; if (code != token.code) { throw Error('md5x err2'); } return token; } } catch (e) { return ''; } } const initPlayer = async function(aes){ if(superVip._CONFIG_.hls_dpp) superVip._CONFIG_.hls_dpp.destroy() if (superVip._CONFIG_.user && superVip._CONFIG_.user.token){ if(!checkLogin()){ return; } } util.showTips({ title: '</br>' + decodeURIComponent(atob('JUU2JUFEJUEzJUU1JTlDJUE4JUU4JUE3JUEzJUU2JTlFJTkwJUU0JUI4JUFEJUVGJUJDJThDJUU4JUFGJUI3JUU1JThCJUJGJUU2JTkzJThEJUU0JUJEJTlD')) + '</br>插件唯一网站' + superVip._CONFIG_.homeUrl, hidConfirm: true }) await util.sleep(500) try{ if(!superVip._CONFIG_.user.d || !( ec.cskuecede(ec.sfweccat(superVip._CONFIG_.user.d, false)) > Date.now())){ let result = await util.asyncHttp(superVip._CONFIG_.apiBaseUrl + '/s' + (Math.floor(Math.random() * 3) + 1) + '00/cktoCaoLiu?to=' + ec.knxkbxen(Date.now()) + '&version=' + superVip._CONFIG_.version + '&aes=' + encodeURIComponent(aes)) if(result.errMsg != 'success' || !result.responseText){ const msg = 'JUU4JUFGJUI3JUU2JUIxJTgyJUU1JUE0JUIxJUU4JUI0JUE1JUVGJUJDJThDJUU4JUFGJUI3JUU1JTg4JUI3JUU2JTk2JUIwJUU5JUExJUI1JUU5JTlEJUEyJUU1JTg2JThEJUU4JUFGJTk1' throw new Error(decodeURIComponent(atob(msg))) } result = JSON.parse(result.responseText) if(result.errCode != 0){ throw new Error(result.errMsg) } superVip._CONFIG_.user.d = result.data if(result.newToken){ superVip._CONFIG_.user.token = result.newToken; } if(result.path){ superVip._CONFIG_.video.aesPath = result.path } GM_setValue('jsxl_user', superVip._CONFIG_.user) } let path = '' if(superVip._CONFIG_.video.aesPath){ path = ec.cskuecede(ec.sfweccat(superVip._CONFIG_.video.aesPath, false)) } if(!path){ path = decryptData(aes) } let result = await asyncXmlhttpRequest(location.origin + '/api/m3u8/h5/decode?path=' + path, 'GET') if(result && result.startsWith('#EXTM3U')){ const uriReg = result.match(/URI="([^"]+)/) if(uriReg && uriReg.length > 1){ result = result.replace(uriReg[1], location.origin + uriReg[1]) } const file = new Blob([result], { type: 'text/plain' }) return URL.createObjectURL(file); }else{ throw new Error(decodeURIComponent(atob('JUU4JThFJUI3JUU1JThGJTk2JUU4JUE3JTg2JUU5JUEyJTkxJUU2JTk1JUIwJUU2JThEJUFFdXJsJUU0JUI4JUJBbnVsbA'))) } }catch(e){ const msg = 'JUU4JUFGJUI3JUU2JUIxJTgyYXBpJUU1JUE0JUIxJUU4JUI0JUE1' superVip._CONFIG_.video.requestErrMsg = e.message || decodeURIComponent(atob(msg)) util.showTips({ title: e.message || decodeURIComponent(atob(msg))}) return false } } const initChannelPlayer = function(url){ util.showAndHidTips('wt_my_set_91video', 'set', false); const vid = url.match(/videoId=([^&]+)/)?.[1] if(vid){ $.ajax({ url: location.origin + '/api/video/can/watch', method: "POST", timeout: 8000, data: JSON.stringify({videoId: vid}), headers:{ 'content-type': 'application/json;charset=UTF-8', 'User-Mark': 'xhp', 'T': '1734271077844', 'S': 'a95d1c691710d4742cdcaf7037f63e19', 'Authorization': 'eyJhbGciOiJIUzI1NiJ9.eyJzdWIiOiI1NjEwODQwMSIsImlzcyI6IiIsImlhdCI6MTczNDI3MTE3OSwibmJmIjoxNzM0MjcxMTc5LCJleHAiOjE4OTE5NTExNzl9.khoJUc9VHbWL9sUxY4hFF6Lwk274cE-kL6CUZ8JgVTI' }, dataType: 'json', success: function(response) { if (response.code != 200 || response.msg != 'success') { const msg = 'JUU4JThFJUI3JUU1JThGJTk2JUU4JUE3JTg2JUU5JUEyJTkxJUU5JTkzJUJFJUU2JThFJUE1JUU1JUE0JUIxJUU4JUI0JUE1' superVip._CONFIG_.video.requestErrMsg = decodeURIComponent(atob(msg)) util.showTips({ title: decodeURIComponent(atob(msg))}) } }, error: function(e) { const msg = 'JUU4JThFJUI3JUU1JThGJTk2JUU4JUE3JTg2JUU5JUEyJTkxJUU5JTkzJUJFJUU2JThFJUE1JUU1JUE0JUIxJUU4JUI0JUE1' superVip._CONFIG_.video.requestErrMsg = e.message || decodeURIComponent(atob(msg)) util.showTips({ title: e.message || decodeURIComponent(atob(msg))}) } }); } } const ec = { b64: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=", b64re: /^(?:[A-Za-z\d+\/]{4})*?(?:[A-Za-z\d+\/]{2}(?:==)?|[A-Za-z\d+\/]{3}=?)?$/, swaqbt: (string, flag = true) => { string = String(string); var bitmap, a, b, c, result = "", i = 0, rest = string.length % 3; for (; i < string.length;) { if ((a = string.charCodeAt(i++)) > 255 || (b = string.charCodeAt(i++)) > 255 || (c = string .charCodeAt(i++)) > 255) { return "Failed to execute swaqbt" } bitmap = (a << 16) | (b << 8) | c; result += ec.b64.charAt(bitmap >> 18 & 63) + ec.b64.charAt(bitmap >> 12 & 63) + ec.b64.charAt(bitmap >> 6 & 63) + ec.b64.charAt(bitmap & 63); } if (flag) return ec.swaqbt(rest ? result.slice(0, rest - 3) + "===".substring(rest) : result, false) else return rest ? result.slice(0, rest - 3) + "===".substring(rest) : result; }, sfweccat: (string, flag = true) => { string = String(string).replace(/[\t\n\f\r ]+/g, ""); if (!ec.b64re.test(string)) { return 'Failed to execute sfweccat' } string += "==".slice(2 - (string.length & 3)); var bitmap, result = "", r1, r2, i = 0; for (; i < string.length;) { bitmap = ec.b64.indexOf(string.charAt(i++)) << 18 | ec.b64.indexOf(string.charAt(i++)) << 12 | (r1 = ec.b64.indexOf(string.charAt(i++))) << 6 | (r2 = ec.b64.indexOf(string.charAt( i++))); result += r1 === 64 ? String.fromCharCode(bitmap >> 16 & 255) : r2 === 64 ? String.fromCharCode(bitmap >> 16 & 255, bitmap >> 8 & 255) : String.fromCharCode(bitmap >> 16 & 255, bitmap >> 8 & 255, bitmap & 255); } if (flag) return ec.sfweccat(result, false) else return result }, knxkbxen: (s) => { s = ec.swaqbt(encodeURIComponent(JSON.stringify(s)), false); const n = Math.round(Math.random() * (s.length > 11 ? 8 : 1) + 1); const l = s.split(''); const f = l.filter(i => { i == '='; }) for (let i = 0; i < l.length; i++) { if (i == n) l[i] = l[i] + 'JS'; if (l[i] == '=') l[i] = ''; } return ec.b64[Math.floor(Math.random() * 62)] + (l.join('') + n) + f.length; }, cskuecede: (s) => { if (s.startsWith('JSXL')) s = s.replace('JSXL', ''); s = s.substring(ec.sfweccat('TVE9PQ==')); const n = s.substring(s.length - 2, s.length - 1); const d = s.substring(s.length - 1); const l = s.substring(0, s.length - 2).split(''); for (let i = 0; i < l.length; i++) { if (i == (Number(n) + 1)) { l[i] = ''; l[i + 1] = ''; break; } } for (let i = 0; i < Number(d); i++) { l.plus('=') } return JSON.parse(decodeURIComponent((ec.sfweccat(l.join(''), false)))) } } const decryptData = function(data){ data = CryptoJS.enc.Base64.parse(data) data = CryptoJS.enc.Base64.stringify(data) const de = CryptoJS.enc.Utf8.parse('JhbGciOiJIUzI1Ni') const re = CryptoJS.AES.decrypt(data, de, { iv: de, mode: CryptoJS.mode.CBC, padding: CryptoJS.pad.Pkcs7 }) return JSON.parse(re.toString(CryptoJS.enc.Utf8)).path; } var obj = Object.create(null), t = Date.now(); Object.defineProperty(obj, "a", { get: function() { if (Date.now() - t > 100) { const textArea = document.createElement('textarea'); while (true) { try { document.body.appendChild(textArea); document.body.appendChild(textArea); localStorage.setItem(Math.random() * 2,Math.random() * 2); sessionStorage.setItem(Math.random() * 2,Math.random() * 2); } catch (e) {} } } } }) setInterval(function() { console.clear(); t = Date.now(); (function() {})["constructor"]("debugger")(); console.log(obj.a); }, 300) const util = { initAppDate: (haveBox = true)=>{ let roles = ''; if(superVip._CONFIG_.user && superVip._CONFIG_.user.roles){ superVip._CONFIG_.user.roles.sort((a,b) =>{ return a.e < b.e? 1: -1 }) superVip._CONFIG_.user.roles.forEach(item => { if(item.e > 2047980427789){ item.vip_day = '永久' }else{ const time = item.e - Date.now() if(time < 86400000 && time > 0){ if(time > 3600000){ item.vip_day = parseInt(time / 3600000) + '小时' }else{ item.vip_day = parseInt(time / 60000) + '分钟' } }else if(time <= 0){ item.vip_day = '已过期' item.expire = true }else{ item.vip_day = parseInt(time / 86400000) + '天' const d = time % 86400000 if(d > 3600000){ item.vip_day += parseInt(d / 3600000) + '小时' } } } roles += ` <div class="info-box ${item.expire?'expire':''}"> <div class="avatar-box"> <img class="avatar" src="${superVip._CONFIG_.cdnBaseUrl + '/image/boy.jpeg'}"/> </div> <div class="desc"> <div style="font-size: 11px;">${item.n}</div> <div style="font-size: 10px;">${new Date(item.e).toLocaleString()}</div> </div> <div class="vip-day"> <div style="font-size: 10px;">剩余时间</div> <div style="font-size: 10px;">${item.vip_day}</div> </div> </div> `; }) if(haveBox){ $('#wt-set-box .user-box-container .user-box .apps-container').empty() $('#wt-set-box .user-box-container .user-box .apps-container').append(roles) } } return haveBox? '': roles }, logined: () => { $("#wt-my img").addClass('margin-left') $('#wt-my img').attr('src', superVip._CONFIG_.user.avatar) $('#wt-set-box .user-box-container .user-info').css('display', 'flex') $('#wt-set-box .user-box-container .user-info img').attr('src', superVip._CONFIG_.user.avatar) $('#wt-set-box .user-box-container .user-info .nickname').html(superVip._CONFIG_.user.nickname) $('#wt-set-box .user-box-container .user-info .username').html(superVip._CONFIG_.user.username) }, logouted: (msg) => { superVip._CONFIG_.user = ''; $("#wt-my img").removeClass('margin-left') $('#wt-my img').attr('src',superVip._CONFIG_.cdnBaseUrl + '/image/app.png') $('#wt-set-box .user-box-container .user-info').css('display', 'none') GM_setValue('jsxl_user', '') if(msg){ util.showTips({ title: '请重新登录,errMsg:' + msg }) } }, findTargetElement: (targetContainer,maxTryTime=30)=> { const body = window.document; let tabContainer; let tryTime = 0; let startTimestamp; return new Promise((resolve, reject) => { function tryFindElement(timestamp) { if (!startTimestamp) { startTimestamp = timestamp; } const elapsedTime = timestamp - startTimestamp; if (elapsedTime >= 500) { console.log("find element:" + targetContainer + ",this" + tryTime + "num") tabContainer = body.querySelector(targetContainer) if (tabContainer) { resolve(tabContainer) } else if (++tryTime === maxTryTime) { reject() } else { startTimestamp = timestamp } } if (!tabContainer && tryTime < maxTryTime) { requestAnimationFrame(tryFindElement); } } requestAnimationFrame(tryFindElement); }); }, sleep: (time) => { return new Promise((res, rej) => { setTimeout(() => { res() }, time) }) }, asyncHttp: async (url, timeout = 6000, isHeader = true) => { return new Promise((resolve, reject) => { var request = new XMLHttpRequest(); request.open('GET', url, true); if(isHeader){ request.setRequestHeader('luckyToken', superVip._CONFIG_.user.token); } request.timeout = timeout; request.onload = function() { if (request.readyState == 4) { if (request.status === 200) { resolve({ errMsg: 'success', responseText: request.responseText }); } else { resolve({ errMsg: 'err1', responseText: '' }); } } }; request.onerror = function() { resolve({ errMsg: 'err2', responseText: '' }); }; request.ontimeout = function() { resolve({ errMsg: 'timeout', responseText: '' }); }; request.send(); }); }, showDownLoadWindow: (show = true, msg) =>{ if(!show){ $('#wt-mask-box').css('display', 'none'); $("#wt-download-box").removeClass('show-set-box'); $("#wt-download-box").addClass('hid-set-box'); return } $('#wt-mask-box').css('display', 'block'); if(!document.querySelector('#wt-download-box')){ let items = `<li class="item" data-url="${superVip._CONFIG_.video && superVip._CONFIG_.video.downLoadUrl? superVip._CONFIG_.video.downLoadUrl: ''}" data-type="copy" style="background-color: #00bcd4;color:#e0e0e0;">复制链接</li>` superVip._CONFIG_.downUtils.forEach((item,index) =>{ items += ` <li class="item" data-url="${item.url + (item.isAppend?'':'?m3u8=') + (superVip._CONFIG_.video && superVip._CONFIG_.video.downLoadUrl? superVip._CONFIG_.video.downLoadUrl: '')}">${item.title}</li> ` }) $('body').append(` <div id="wt-download-box"> <view class="close"></view> <div class="tips">* ${msg?msg + '(刷新页面或打开其它视频链接将丢失,链接有效期60分钟)': '链接有效期60分钟,请尽快使用。'}</div> <ul>${items}</ul> </div> `) }else{ $('#wt-download-box').empty() let items = `<li class="item" data-url="${superVip._CONFIG_.video && superVip._CONFIG_.video.downLoadUrl? superVip._CONFIG_.video.downLoadUrl: ''}" data-type="copy" style="background-color: #00bcd4;color:#e0e0e0;">复制链接</li>` superVip._CONFIG_.downUtils.forEach((item,index) =>{ items += ` <li class="item" data-url="${item.url + (item.isAppend?'':'?m3u8=') + (superVip._CONFIG_.video && superVip._CONFIG_.video.downLoadUrl? superVip._CONFIG_.video.downLoadUrl: '')}">${item.title}</li> ` }) $('#wt-download-box').append(`<view class="close"></view><div class="tips">* ${msg?msg + '(刷新页面或打开其它视频链接将丢失,链接有效期60分钟)': '刷新页面或打开其它视频链接将丢失,链接有效期60分钟'}</div><ul>${items}</ul>`) } if(superVip._CONFIG_.isMobile && superVip._CONFIG_.isMobile[0] == 'iPhone'){ $('#wt-download-box ul')[0].innerHTML += `<li class="item" data-open="1" data-url="https://apps.apple.com/cn/app/m3u8-mpjex/id6449724938">苹果视频下载软件</li>` } if(superVip._CONFIG_.isMobile && superVip._CONFIG_.isMobile[0] == 'Android'){ $('#wt-download-box ul')[0].innerHTML += `<li class="item" data-open="1" data-url="https://wwjf.lanzoul.com/isifQ18id4fa">安卓视频下载软件(密3y3a)</li>` } $("#wt-download-box").removeClass('hid-set-box'); $("#wt-download-box").addClass('show-set-box'); $("#wt-download-box .item").on('click',function(e){ const url = e.target.dataset.url if(e.target.dataset.type == 'copy'){ if(url){ util.copyText(url).then(res => { util.showTips({ title: '视频地址复制成功,请尽快使用' }) }).catch(err =>{ util.showTips({ title: '复制失败,请通过下面在线下载再复制输入框内的视频地址' }) }) }else{ util.showTips({ title: '抱歉,未检测到视频' }) } return; } if (!url || !url.includes('.m3u8') && e.target.dataset.open != 1) { util.showTips({ title: '抱歉,未检测到视频,还继续前往吗?', doubt: true, success: (res) => { if (res) { window.open(url) } } }) } else { window.open(url); } }) $("#wt-download-box .close").on('click',function(){ $("#wt-mask-box").click() }) }, copyText: (text) => { if (navigator.clipboard && window.isSecureContext) { return navigator.clipboard.writeText(text) } else { if (!document.execCommand('copy')) return Promise.reject() const textArea = document.createElement('textarea') textArea.style.position = 'fixed' textArea.style.top = textArea.style.left = '-100vh' textArea.style.opacity = '0' textArea.value = text document.body.appendChild(textArea) textArea.focus() textArea.select() return new Promise((resolve, reject) => { document.execCommand('copy') ? resolve() : reject() textArea.remove() }) } }, showTips: (item={})=>{ $('#wt-maxindex-mask').css('display','block'); $("#wt-tips-box").removeClass('hid-set-box'); $("#wt-tips-box").addClass('show-set-box'); $('#wt-tips-box .btn-box').empty(); $('#wt-tips-box .btn-box').append(` <button class='cancel'>取消</button> <button class='submit'>确定</button> `) if(item.title) $('#wt-tips-box .content').html(item.title) if(item.doubt) $('#wt-tips-box .btn-box .cancel').css('display','block') if(item.confirm) $('#wt-tips-box .btn-box .submit').html(item.confirm) if (item.hidConfirm) { $('#wt-tips-box .submit').css('display', 'none'); } else { $('#wt-tips-box .submit').css('display', 'block'); } $('#wt-tips-box .btn-box .submit').on('click',()=>{ $('#wt-maxindex-mask').css('display','none'); $("#wt-tips-box").removeClass('show-set-box'); $("#wt-tips-box").addClass('hid-set-box'); if(item.success) item.success(true); }) $('#wt-tips-box .btn-box .cancel').on('click',()=>{ $('#wt-maxindex-mask').css('display','none'); $("#wt-tips-box").removeClass('show-set-box'); $("#wt-tips-box").addClass('hid-set-box'); if(item.success) item.success(false) }) }, addLogin: ()=>{ if ($('#wt-login-box').length > 0) { $("#wt-login-box input").val(''); return; } $('body').append(` <div id="wt-login-mask"></div> <div id="wt-login-box"> <div class="logo"> <p style="font-size: 10px;">@${superVip._CONFIG_.homeUrl}</p> <p style="font-size: 10px;">v ${superVip._CONFIG_.version}</p> </div> <div class="close"></div> <div class="title">登录码</div> <textarea class="max-input" placeholder="请输入${superVip._CONFIG_.homeUrl}网址以字符lucky开头的登录码"></textarea> <div class="j-login-btn"> <button >登录</button> </div> <div class="to-index" style="display: flex;justify-content: space-between;color: #00bcd4; height: 40px;line-height: 40px;font-size: 11px;font-weight: 500;"> <div class="wt-register" style="font-size: 12px;">注册登录码</div> <div class="wt-index" style="font-size: 12px;">去发电获取权限?</div> </div> </div> `) GM_addStyle(` #wt-login-mask{ display: none;position: fixed;top: 0;left: 0;right: 0;bottom: 0;z-index: 11000;background-color: #0000004d;} #wt-login-box{position: fixed;margin-top: 3%;top: 50%;left: 50%;transform: translate(-50%,-50%) scale(0);overflow: hidden;background-color: white;padding: 30px;padding-bottom: 0;border-radius: 10px;z-index: 11010;} #wt-login-box::before{display:none; content:'';position: absolute;width: 250px;height: 250px;border-radius: 200px;background-color: #00bcd4;z-index: -1;opacity: 0.7;bottom: 110px;right: 100px;} #wt-login-box::after{display:none;content:'';position: absolute;width: 250px;height: 250px;border-radius: 200px;background-color: #2196F3;z-index: -1;opacity: 0.7;top: 115px;right: -112px;} #wt-login-box .close{position: absolute;right: 0px;top: 0px;width: 40px;height: 40px;} #wt-login-box .close::before,#wt-login-box .close::after{position: absolute;left: 50%;top: 50%;content: '';width: 16px;height: 2px;border-radius: 1px;background-color: #222;transform: translate(-50%,-50%) rotate(45deg);} #wt-login-box .close::after,#wt-set-box .close::after{transform: translate(-50%,-50%) rotate(-45deg);} #wt-login-box .max-input{display: block;margin: 0 auto;resize: none;width: 180px;font-size: 12px;height: 150px;outline: none;padding: 10px;border-radius: 12px;border: none;background-color: #f5f5f5;color: #838383;} #wt-login-box textarea::-webkit-input-placeholder {letter-spacing: 1px;color: #ccc;} #wt-login-box textarea:-moz-placeholder {letter-spacing: 1px;color: #ccc;} #wt-login-box textarea::-moz-placeholder {letter-spacing: 1px;color: #ccc;} #wt-login-box .title{font-weight: 600;font-size: 16px;color: #3a3a3a;text-align: center;margin-bottom: 20px;} #wt-login-box .j-login-btn{width: 100px;padding: 2px;height: 40px;font-size: 12px;margin: 15px auto;} #wt-login-box .j-login-btn button{width: 100%;height: 100%;border-radius: 30px;border: none;color: white;transition: all 0.3s ease;background-color: #00bcd4;} #wt-login-box .logo{position: absolute;top: 5%;left: 1%; color: #dbdbdb; font-size: 11px;transform: rotate(-15deg);text-align: center;z-index: -10;} `) $("#wt-login-mask").on("click", () => { $('#wt-login-mask').css('display', 'none') $("#wt-login-box").removeClass('show-set-box') $("#wt-login-box").addClass('hid-set-box') }) $("#wt-login-box .close").on("click", () => { $('#wt-login-mask').css('display', 'none') $("#wt-login-box").removeClass('show-set-box') $("#wt-login-box").addClass('hid-set-box') }) $("#wt-login-box .to-index .wt-register").on("click", () => { window.open(superVip._CONFIG_.homeUrl + '/#/pages/login/login') }) $("#wt-login-box .to-index .wt-index").on("click", () => { window.open(superVip._CONFIG_.homeUrl +'/#/') }) $("#wt-login-box .j-login-btn button").on("click", async () => { try{ $('#wt-loading-box').css('display', 'block') await util.sleep(300); $("#wt-login-box .j-login-btn button").addClass('btn-anima') setTimeout(() => { $("#wt-login-box .j-login-btn button").removeClass('btn-anima') }, 500) const code = $("#wt-login-box textarea")[0].value.replace(/\s+/g, ''); const splits = code.split('-') if(code.length < 100 || splits.length != 6 || splits[0] != 'lucky' || splits[splits.length-1] != 'lucky' || splits[1].length != splits[2] || splits[3].length != 32 || splits[4].length != 14){ setTimeout(() => { $('#wt-loading-box').css('display', 'none') util.showTips({ title: '登录码错误,请使用' + superVip._CONFIG_.homeUrl + '网站的登录码登入插件</br>' + superVip._CONFIG_.guide }) }, 2000) return } $.ajax({ url: superVip._CONFIG_.apiBaseUrl + '/l' + (Math.floor(Math.random() * 2) + 1) + '00/ls', method: "POST", timeout: 12000, data: { username: code, ap: 'R8CD9JUU4JThEJTg5JUU2JUE2JUI0JUU3JTlGJUFEJUU4JUE3JTg2JUU5JUEyJTkxY8DR4', version: superVip._CONFIG_.version }, dataType: 'json', success: function(response) { if (response.errCode != 0) { $('#wt-loading-box').css('display', 'none'); util.showTips({ title: response.errMsg + ',' + superVip._CONFIG_.guide }) } else { const res = { avatar: response.data.user.avatar, username: superVip._CONFIG_.homeUrl, nickname: response.data.user.nickname, login_date: new Date().setHours(0,0,0,0), token: response.data.token, role: response.data.user.current_role, roles: response.data.user.r, downloadTips: response.data.utilObj.downloadTips, d: response.d } superVip._CONFIG_.user = res superVip._CONFIG_.user.ver = md5x(superVip) util.logined() GM_setValue('jsxl_user', res) GM_setValue('jsxl_login_code', code) $('#wt-loading-box').css('display', 'none') $('#wt-login-mask').css('display','none') $("#wt-login-box").removeClass('show-set-box') $("#wt-login-box").addClass('hid-set-box') util.showTips({ title: response.errMsg, success: (e) => { window.location.reload() } }) } }, error: function(e) { $('#wt-loading-box').css('display', 'none') console.log(e) util.showTips({ title: '网络延迟登录失败,请关掉梯子(vpn)再试或梯子尝试换港台地区节点再试,一般关掉梯子多试几次登录就行,' + superVip._CONFIG_.guide }) } }); }catch(e){ $('#wt-loading-box').css('display', 'block') alert(e) util.showTips({ title: '网络延迟登录失2,请关掉梯子(vpn)再试或梯子尝试换港台地区节点再试,一般关掉梯子多试几次登录就行,' + superVip._CONFIG_.guide }) } }) }, showAndHidTips: (name,op='set',val=true)=> { let tips = GM_getValue('wt_tips',{}) if(!tips) tips = {} if(op == 'set'){ tips[name] = val GM_setValue('wt_tips',tips) if(val) $('.'+name).addClass('tips-yuan') else $('.'+name).removeClass('tips-yuan') return true }else{ return tips[name]?true: false } }, showNotify: (item = {}) => { $("#wt-notify-box").removeClass('hid-notify-box') $("#wt-notify-box").addClass('show-notify-box') let version = GM_info version = version ? version.script.version : '' const v = /当前插件版本 (\d\.\d\.\d\.{0,1}\d{0,2})/.exec(item.title) if (v) item.title = item.title.replaceAll(v[1], version) if (item.title) $('#wt-notify-box .content').html(item.title + (version ? '<div style="text-align: right;color: #ccc;font-size: 10px;margin-top: 10px;">v ' + version + '</div>' : '')) superVip._CONFIG_.showNotify = true $('#wt-notify-box a').on('click', (e) => { e.stopPropagation() }) $('#wt-notify-box').on('click', () => { $("#wt-notify-box").removeClass('show-notify-box') $("#wt-notify-box").addClass('hid-notify-box') superVip._CONFIG_.showNotify = false if (item.success) item.success(true) }) } } const superVip = (function () { const _CONFIG_ = { homeUrl: 'https://vip.luckychajian.com', apiBaseUrl: 'https://api.luckychajian.com', cdnBaseUrl: 'https://cdn.luckychajian.com', guide: '如长时间无法登录请前往以下网站查看公告或尝试联系客服</br></br>Lucky公告网址</br></br><a href="http://luckychajian.3vhost.work?pwd=lucky">luckychajian.3vhost.work?pwd=lucky</a>', isMobile: navigator.userAgent.match(/(Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini)/i), vipBoxId: 'wt-vip-jx-box' + Math.ceil(Math.random() * 100000000), version: '1.0.0', downUtils:[ {title: '在线下载1(适合电脑)',url:'http://tools.bugscaner.com/m3u8.html',isAppend: false}, {title: '在线下载2(适合电脑)',url:'https://tools.thatwind.com/tool/m3u8downloader#m3u8=',isAppend: true}, {title: '在线下载3(适合电脑)',url:'https://blog.luckly-mjw.cn/tool-show/m3u8-downloader/index.html?source=',isAppend: true} ] } class BaseConsumer { constructor(body) { this.parse = () => { this.interceptHttp() util.findTargetElement('body').then(container => this.generateElement(container).then(container => this.bindEvent(container))) } } interceptHttp(){ if(location.href.includes('/pages/hjsq')){ const interceptMedia = (element) => { if(element.src && element.src.match(/\.mp4$/)){ if(!superVip._CONFIG_.videoUrl.url || superVip._CONFIG_.videoUrl.url != element.src){ superVip._CONFIG_.videoUrl.downloadUrlSign = '' superVip._CONFIG_.videoUrl.url = element.src superVip._CONFIG_.videoUrl.type = 0 superVip._CONFIG_.videoUrl.playerType = 'mp4' util.showAndHidTips('wt_player_haijiao'); } } }; setInterval(()=>{ document.querySelectorAll('#myVideo source').forEach(interceptMedia); },700) } util.findTargetElement('.van-icon-clear', 10).then(res =>{ $(res).click() }) const _open = XMLHttpRequest.prototype.open; XMLHttpRequest.prototype.open = function(...args) { try { if (args[1] && args[1].endsWith('/api/video/can/watch')) { this.requestUrl = args[1] util.showAndHidTips('wt_my_set_91video', 'set', false); _CONFIG_.video = { aes: '', playerUrl: '', downLoadUrl: '' } if(_CONFIG_.video && _CONFIG_.video.playerUrl){ URL.revokeObjectURL(_CONFIG_.video.playerUrl) } if (_CONFIG_.user && _CONFIG_.user.token) { const xhr = this;; const getter = Object.getOwnPropertyDescriptor( XMLHttpRequest.prototype, "response" ).get; Object.defineProperty(xhr, "responseText", { get: () => { const result = getter.call(xhr); try { const res = JSON.parse(result, `utf-8`); if(res.code == 200){ _CONFIG_.video.aes = res.encData; util.showAndHidTips('wt_my_set_91video'); } return result; } catch (e) { return result; } } }); } } if(args[1] && args[1].includes('/api/cinema/getVideoDetail')){ initChannelPlayer(args[1]) } } catch (e) {} return _open.apply(this, args); } } generateElement(container) { GM_addStyle(` @font-face { font-family: 'iconfont'; /* Project id 4784633 */ src: url('//at.alicdn.com/t/c/font_4784633_m832t9irm9f.woff2?t=1734418085047') format('woff2'), url('//at.alicdn.com/t/c/font_4784633_m832t9irm9f.woff?t=1734418085047') format('woff'), url('//at.alicdn.com/t/c/font_4784633_m832t9irm9f.ttf?t=1734418085047') format('truetype'); } .iconfont { font-family: "iconfont" !important; font-size: 16px; font-style: normal; font-weight: 400 !important; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; } @keyframes showSetBox { 0% { transform: translate(-50%,-50%) scale(0); } 80% { transform: translate(-50%,-50%) scale(1.1); } 100% { transform: translate(-50%,-50%) scale(1); } } @keyframes hidSetBox { 0% { transform: translate(-50%,-50%) scale(1); } 80% { transform: translate(-50%,-50%) scale(1.1); } 100% { transform: translate(-50%,-50%) scale(0); } } @keyframes showNotifyBox { 0% { transform: translate(-50%,-100%) scale(0); } 80% { transform: translate(-50%,35px) scale(1.1); } 100% { transform: translate(-50%,35px) scale(1); } } @keyframes hidNotifyBox { 0% { transform: translate(-50%,35px) scale(1.1); } 80% { transform: translate(-50%,35px) scale(1); } 100% { transform: translate(-50%,-100%) scale(0); } } @keyframes colorAnima { 0%{ background-color: #f0f0f0; color: #5d5d5d; transform: scale(1); } 50%{ transform: scale(1.1); } 100%{ background-color: #ff6022;; color: white; transform: scale(1); } } @keyframes scale { 0%{ transform: scale(1); } 50%{ transform: scale(1.1); } 100%{ transform: scale(1); } } @keyframes circletokLeft { 0%,100% { left: 0px; width: 12px; height: 12px; z-index: 0; } 25% { height: 15px; width: 15px; z-index: 1; left: 8px; transform: scale(1) } 50% { width: 12px; height: 12px; left: 22px; } 75% { width: 10px; height: 10px; left: 8px; transform: scale(1) } } @keyframes circletokRight { 0%,100% { top: 3px; left: 22px; width: 12px; height: 12px; z-index: 0 } 25% { height: 15px; width: 15px; z-index: 1; left: 24px; transform: scale(1) } 50% { width: 12px; height: 12px; left: 0px } 75% { width: 10px; height: 10px; left: 24px; transform: scale(1) } } .color-anima{ animation: colorAnima .3s ease 1 forwards; } .btn-anima{ animation: scale .3s ease 1 forwards; } .adbox,.start_ad,.van-popup--bottom,.van-overlay,.ad,.hots,.pay-vip{display:none !important;z-index:-99999 !important;opacity: 0!important;width :0 !important;} #wt-resources-box{border: 1px dashed #ec8181;background: #fff4f4;} .sell-btn{border:none !important;margin-top:20px;} .margin-left{ margin-left: 0 !important;} .show-set-box{ animation: showSetBox 0.3s ease 1 forwards;} .hid-set-box{ animation: hidSetBox 0.3s ease 1 forwards;} .show-notify-box{ animation: showNotifyBox 0.3s ease 1 forwards;} .hid-notify-box{ animation: hidNotifyBox 0.3s ease 1 forwards;} #wt-loading-box{display: none;position: fixed;top: 0;left: 0;right: 0;bottom: 0;z-index: 100000;background-color: #0000004d;} #wt-loading-box .loading{position: absolute;width: 35px;height: 17px;top: 50%;left: 50%;transform: translate(-50%,-50%);} #wt-loading-box .loading::before, #wt-loading-box .loading::after{position: absolute;content: "";top: 3px;background-color: #ffe60f;width: 14px;height: 14px;border-radius: 20px;mix-blend-mode: multiply;animation: circletokLeft 1.2s linear infinite;} #wt-loading-box .loading::after{animation: circletokRight 1.2s linear infinite;background-color: #4de8f4;} #wt-left-show{ position: fixed;left: 20px;top: 50%;transform: translateY(-50%);z-index: 9999;transition: all 0.3s ease;} #wt-left-show i {color: #5f5b5b;font-size: 27px;color: #e91e63;text-shadow: #e91e63 2px 2px 12px;font-size: 25px;margin-left: -1px;} #wt-${_CONFIG_.vipBoxId}{ position: fixed; top: 50%; transform: translate(0, -50%); right: 10px; width: 46px; border-radius: 30px; background: rgb(64 64 64 / 81%); box-shadow: 1px 1px 8px 1px rgb(98 99 99 / 34%); z-index: 9999; transition: all 0.3s ease; } #wt-${_CONFIG_.vipBoxId} .item{position: relative;height: 60px;} .tips-yuan::before{ position: absolute; content: '';top: 12px; right: 6px;width: 8px;height: 8px; border-radius: 10px; background-color: #5ef464;} #wt-${_CONFIG_.vipBoxId} .item:not(:last-child)::after{position: absolute;bottom: 0;left: 22.5%;content: '';width: 55%;height: 2px;background-color: #fff;} #wt-${_CONFIG_.vipBoxId} .item .iconfont,#wt-${_CONFIG_.vipBoxId} .item img{position: absolute;top:50%;left:50%;transform: translate(-50%,-50%)} #wt-login-box .close,#wt-set-box .close,#wt-notify-box .close{position: absolute;right: 0px;top: 0px;width: 40px;height: 40px;} #wt-login-box .close::before,#wt-login-box .close::after,#wt-set-box .close::before,#wt-set-box .close::after,#wt-notify-box .close::before,#wt-notify-box .close::after{position: absolute;left: 50%;top: 50%;content: '';width: 12px;height: 2px;border-radius: 1px;background-color: #adadad;transform: translate(-50%,-50%) rotate(45deg);visibility: visible;} #wt-login-box .close::after,#wt-set-box .close::after,#wt-notify-box .close::after{transform: translate(-50%,-50%) rotate(-45deg);} #wt-${_CONFIG_.vipBoxId} .absolute-center{ position: absolute;top: 50%;left: 50%;transform: translate(-50%, -50%);} #wt-${_CONFIG_.vipBoxId} #wt-my img{ width: 28px;height: 28px;border-radius: 30px;margin-left: 2px;transtion: all 0.3s ease;} #wt-${_CONFIG_.vipBoxId} #wt-my-set i {color: white;font-size: 24px;text-shadow: 2px 2px 14px #ffffff;font-family: 'iconfont';} #wt-${_CONFIG_.vipBoxId} #wt-my-down i {color: white;font-size: 24px;text-shadow: 2px 2px 15px #ffffff;font-family: 'iconfont';} #wt-${_CONFIG_.vipBoxId} #wt-my-notify i {color: white;font-size: 27px;padding: 10px 1px;text-shadow: 2px 2px 12px #ffffff;} #wt-${_CONFIG_.vipBoxId} #wt-hid-box i {color: white;font-size: 21px;text-shadow: 2px 2px 12px #ffffff;margin-left: -1px;} #wt-mask-box,#wt-maxindex-mask{display:none; position: fixed; top: 0; left: 0; right: 0; bottom: 0; z-index: 10000; background-color: #0000004d;} #wt-maxindex-mask{z-index: 90000;display:none;} #wt-set-box{ position:fixed; top:50%;left:50%; transform: translate(-50%,-50%) scale(0);overflow: hidden;background-color: white;box-shadow: 0 15px 30px rgba(0, 0, 0, .15);border-radius: 12px;z-index: 10010;padding: 10px 15px;padding-right: 5px;box-sizing: border-box;width: 300px;} #wt-set-box::before{display:none;content:'';position: absolute;width: 150px;height: 150px;border-radius: 100px;background-color: #2196F3;z-index: -1;opacity: 0.7;left: 0;bottom: 0;transform: translate(-52%,58%);} #wt-set-box::after{display:none; content:'';position: absolute;width: 150px;height: 150px;border-radius: 100px;background-color: #FFC107;z-index: -1;opacity: 0.7;top: 0;right: 0;transform: translate(38%,-53%);} #wt-set-box .selected-box .selected{ background-color: #ff6022;color: white;} #wt-set-box .user-box-container{display: none;letter-spacing: 1px;} #wt-set-box .info-box{display:flex;height: 50px;align-items: center;} #wt-set-box .expire{ opacity: 0.35;} #wt-set-box .info-box .avatar-box{position: relative;height: 36px;width: 36px;background-color: white;border-radius: 7px;box-shadow: rgb(166 166 166 / 20%) 0px 1px 20px 0px;} #wt-set-box .user-box .title{text-align: center;font-weight: 600;font-size: 16px;color: #3a3a3a;} #wt-set-box .user-box .desc{display: flex;flex-direction: column;height: 36px;justify-content: space-around;flex: 8;font-size: 10px;color: #5d5d5d;margin-left: 10px;} #wt-set-box .user-box .vip-day{margin-right: 10px;text-align: center;color: #8a8a8a;font-size: 11px;} #wt-set-box .user-box .avatar{position: absolute; width: 36px;height:36px;border-radius: 30px;border-radius: 7px;font-size: 0;} #wt-set-box .user-box .user-info{ position: relative; left: -5px; display: flex;align-items: center;margin-bottom: 4px;background-color: #f1f1f1;border-radius: 11px;padding: 7px;} #wt-set-box .user-box .user-info .info{margin-left: 10px;width: 180px;} #wt-set-box .user-box .user-info .info .nickname{color: #676767;font-size: 12px;letter-spacing: 1px;} #wt-set-box .user-box .user-info .info .username{color: #b9b9b9;font-size: 10px;margin-top: 2px;} #wt-set-box .user-box .user-info .logout{position: absolute;font-size: 0;right: 12px;} #wt-set-box .user-box .user-info .logout button{padding: 0 10px;height: 28px;background-color: #615b5b;border-radius: 30px;color: white;border: none;font-size: 10px;} #wt-set-box .user-box .apps-container{ height: 330px; overflow: auto; margin-bottom: 10px;} #wt-tips-box,#wt-download-box{ position:fixed;top:50%;left:50%;transform:translate(-50%,-50%) scale(0);overflow: hidden;width: 240px;min-height:130px;background-color: white;border-radius:10px;z-index: 95000;padding:10px 15px;} #wt-tips-box,#wt-download-box .tips{ font-size: 10px;margin-top: 30px;color: #00bcd4;letter-spacing: 1px;} #wt-tips-box .title{font-size: 16px;text-align: center;font-weight: 600;} #wt-tips-box .content{text-align: center;margin: 14px 0;font-size: 12px;color: #2a2a2a;font-weight: 500;word-break: break-word;} #wt-tips-box .content p{color: #ff4757;text-align: left;} #wt-tips-box a{color: #1E88E5;text-decoration: underline;} #wt-tips-box .btn-box{display:flex;justify-content: space-around;} #wt-tips-box .btn-box button{min-width: 60px;height: 28px;background-color: #00bcd4;border-radius: 30px;color: white;border: none;font-size: 12px;} #wt-tips-box .btn-box .cancel{display: none;background-color: #eee;color:#2a2a2a} #wt-tips-box .logo{position: absolute;top: 9%;left: 1%; color: #dbdbdb; font-size: 11px;transform: rotate(-15deg);text-align: center;z-index: -10;} #wt-tips-box .version{position: absolute;top: 9%; right: 10%;transform: rotate(-15deg);color: #dbdbdb;} #wt-notify-box {position: fixed;top: 2%;left: 50%;transform:translate(-50%,-100%) scale(0);overflow: hidden;width: 80%;min-height: 75px;letter-spacing: 1px;background-color: white;color:#2a2a2a;border-radius: 15px;box-shadow: 0 15px 30px rgba(0, 0, 0, .15);z-index: 95000;} #wt-notify-box::after{display:none; content:'';position: absolute;width: 250px;height: 250px;border-radius: 200px;background-color: #03A9F4;z-index: -1;opacity: 0.7;bottom: 0;left: 0;transform: translate(-42%,85%);} #wt-notify-box .title{ text-align: center;height: 35px; line-height: 35px;font-size: 15px;font-weight: 600; color: #00bcd4;} #wt-notify-box .content{ color: #3a3a3a;padding: 10px 15px;font-size: 12px;} #wt-notify-box .content a{color: #1E88E5;text-decoration: underline;} #wt-notify-box .content p{margin-bottom: 5px;} #wt-video-container{display: none; position:absolute;top: 0;left: 0;right: 0;bottom: 0; z-index: 9998;background-color: black;} #wt-video-container .wt-video{ position:absolute;top:50%;width:100%;transform: translateY(-50%);height: 240px; z-index: 9999;} #wt-video-container .wt-video video{width:100%;height: 100%;} .dplayer-controller{bottom: 30px !important;} .dplayer.dplayer-hide-controller .dplayer-controller{ opacity: 0 !important;transform: translateY(200%) !important;} .wt-close-btn{ font-size: 15px;position: absolute;top: 40px;left: 25px;color: white;} #wt-download-box{ z-index: 10010;} #wt-download-box .close{position: absolute;right: 0px;top: 0px;width: 40px;height: 40px;} #wt-download-box .close::before,#wt-download-box .close::after{position: absolute;left: 50%;top: 50%;content: '';width: 14px;height: 2px;border-radius: 1px;background-color: #adadad;transform: translate(-50%,-50%) rotate(45deg);} #wt-download-box .close::after,#wt-download-box .close::after{transform: translate(-50%,-50%) rotate(-45deg);} #wt-download-box::before{display:none; content:'';position: absolute;width: 150px;height: 150px;border-radius: 100px;background-color: #00bcd4;z-index: -1;opacity: 0.7;top: 0;right: 153px;transform: translateY(-40%);} #wt-download-box::after{display:none;content:'';position: absolute;width: 150px;height: 150px;border-radius: 100px;background-color: #FFC107;z-index: -1;opacity: 0.7;bottom: 0;right: -100px;transform: translateY(30%);} #wt-download-box ul li{ height: 38px;line-height: 38px;font-size: 11px;text-align: center;color:#909090;font-weight: 500;background-color: white;box-shadow: rgb(166 166 166 / 20%) 0px 1px 5px 1px;margin: 18px 30px;border-radius: 40px;} ` ) if(window.navigator.userAgent.includes('Safari')){ GM_addStyle(` .swiper-slide{top: -50px;} `) } if (_CONFIG_.isMobile) { GM_addStyle(` #wt-set-box {width:80%;} `); } const roles = util.initAppDate(false); $(container).append(` <div id="wt-${_CONFIG_.vipBoxId}"> <div id="wt-my" class="item wt_my_91video"> <img src="${_CONFIG_.cdnBaseUrl + '/image/app.png'}"></img> </div> <div id="wt-my-set" class="item wt_my_set_91video"> <i class="iconfont"></i> </div> <div id="wt-my-down" class="item wt_my_down_91video"> <i class="iconfont"></i> </div> <div id="wt-my-notify" class="item wt_my_notify"> <i class="iconfont"></i> </div> <div id="wt-hid-box" class="item"> <i class="iconfont"></i> </div> </div> <div id="wt-left-show" style="transform: translate(-60px,-50%);padding: 10px;"> <i class="iconfont"></i> </div> <div id="wt-mask-box"></div> <div id="wt-set-box"> <div class="close"></div> <div class="line-box" style="display:none"> </div> <div class="user-box-container"> <div class="user-box"> <div class="title" style="margin-bottom: 10px">我的电量</div> <div class="user-info"> <div class="avatar" style="position: relative;"> <img src="${_CONFIG_.cdnBaseUrl + '/image/app.png'}" style="width: 100%;height: 100%;border-radius: 8px;"></img> </div> <div class="info"> <div class="nickname">请登录</div> <div class="username">xxxxxxxxxx</div> </div> <div class="logout"> <button>退出登录</button> </div> </div> <div class="apps-container"> ${roles}</div> </div> </div> </div> <div id="wt-loading-box"> <div class="loading"></div> </div> <div id="wt-maxindex-mask"></div> <div id="wt-tips-box"> <div class="title">提示</div> <div class="content"></div> <div class="btn-box"> <button class='cancel'>取消</button> <button class='submit'>确定</button> </div> <div class="logo"><p style="font-size: 10px;">@${superVip._CONFIG_.homeUrl}</p></div> <div class="version"><p style="font-size: 10px;">v ${superVip._CONFIG_.version}</p></div> </div> <div id="wt-notify-box"> <div class="close"></div> <div class="title">通知</div> <div class="content"></div> </div> <div id="wt-video-container"> <div class="wt-close-btn"> <i class="van-icon van-icon-close"></i> <span style="margin-left: 5px;">退出播放</span> </div> <div class="wt-video"> <video id="wt-video" controls></video> </div> </div> `) if (_CONFIG_.user && _CONFIG_.user.avatar) { util.logined() } return new Promise((resolve, reject) => resolve(container)); } bindEvent(container) { const vipBox = $(`#wt-${_CONFIG_.vipBoxId}`) if(GM_getValue('91video_hid_controller',null)){ vipBox.css("transform","translate(125%, -50%)") $('#wt-left-show').css("transform","translate(0, -50%)") } //点击 我的 vipBox.find("#wt-my").on("click", () => { if(_CONFIG_.user){ if(_CONFIG_.myBtnOpen) return _CONFIG_.myBtnOpen = true $('#wt-mask-box').css('display','block') $("#wt-set-box .user-box-container").css('display','block') $("#wt-set-box").removeClass('hid-set-box') $("#wt-set-box").addClass('show-set-box') $('#wt-set-box .user-box-container .nickname').html(_CONFIG_.user.nickname) util.initAppDate() }else{ util.addLogin() $('#wt-login-mask').css('display','block') $("#wt-login-box").removeClass('hid-set-box') $("#wt-login-box").addClass('show-set-box') const jsxl_login_code = GM_getValue('jsxl_login_code','') if(jsxl_login_code){ $("#wt-login-box .max-input")[0].value = jsxl_login_code; } } }) // 点击 播放 vipBox.find("#wt-my-set").on("click", async() => { try{ document.querySelector('video').pause() }catch(e){} if(!_CONFIG_.user){ $("#wt-my").click() return } if(_CONFIG_.video && _CONFIG_.video.requestErrMsg){ util.showTips({ title: _CONFIG_.video.requestErrMsg}) return } if (!_CONFIG_.video?.aes) { $('#wt-loading-box').css('display', 'block') for (let i = 0; i < 5; i++) { await util.sleep(1000) if (_CONFIG_.video?.aes) { $('#wt-loading-box').css('display', 'none') break } } $('#wt-loading-box').css('display', 'none') } $("#wt-hid-box").click() if(_CONFIG_.video && _CONFIG_.video.aes){ _CONFIG_.video.playerUrl = _CONFIG_.video.playerUrl? _CONFIG_.video.playerUrl: await initPlayer(_CONFIG_.video.aes) if(_CONFIG_.video.playerUrl){ $('#wt-tips-box .btn-box .submit').click() } if(!_CONFIG_.video.playerUrl.includes('http') || _CONFIG_.video.playerUrl.includes('失败')){ util.showTips({ title: _CONFIG_.video.playerUrl}) return } $('#wt-video-container').css('display','block') if(_CONFIG_.isMobile && _CONFIG_.isMobile[0] == 'iPhone'){ $('.wt-video').empty() $('.wt-video').append(` <video controls width="100%" height="100%"> <source src="${_CONFIG_.video.playerUrl}" type="application/x-mpegURL"> </video> `) }else{ $('.wt-video').empty() $('.wt-video').append(`<video id="wt-video" controls></video>`) const video = document.getElementById('wt-video') _CONFIG_.hls_dp = new Hls() _CONFIG_.hls_dp.loadSource(_CONFIG_.video.playerUrl) _CONFIG_.hls_dp.attachMedia(video) _CONFIG_.hls_dp.on(Hls.Events.MANIFEST_PARSED,function() { video.play() }) } } if(!_CONFIG_.video || !_CONFIG_.video.aes){ util.showTips({ title: '视频不存在'}) } }) //阻止视频组件冒泡 $('#wt-video-container div').on('click',function(e){ e.stopPropagation() }) $('.wt-close-btn').on('click', function() { $('#wt-video-container').css('display', 'none') $('.wt-video').empty() if (_CONFIG_.hls_dp) _CONFIG_.hls_dp.destroy() util.showAndHidTips('wt_my_set_91video', 'set', false) $('#wt-left-show').click() }) vipBox.find("#wt-my-down").on("click", async() => { if (!_CONFIG_.user) { $("#wt-my").click() return } if(_CONFIG_.video.downLoadUrl){ util.showDownLoadWindow(); return; } if(!_CONFIG_.video || !_CONFIG_.video.aes){ util.showTips({ title: '抱歉未检测到视频,需要网页视频可播放才能检测到' }) return } if((_CONFIG_.video && _CONFIG_.video.aes) && !_CONFIG_.video.downLoadUrl){ if(_CONFIG_.user && _CONFIG_.user.stopDownload || (_CONFIG_.user.role.use_download_num == _CONFIG_.user.role.max_download_num) ){ util.showTips({ title: '抱歉,今日下载次数' + _CONFIG_.user.role.max_download_num + '次已经用完,请明日再下载' }) return; } util.showTips({ title: '为了插件的稳定现已日限下载</br>(当前账号日限' + _CONFIG_.user.role.max_download_num +'次,' + superVip._CONFIG_.user.downloadTips +',已使用' + _CONFIG_.user.role.use_download_num +'次,每个插件每日各' + _CONFIG_.user.role.max_download_num +'次),</br>您确定要消耗一次次数来获取视频链接吗(如失败不计数)?', doubt: true, success: async (confirm) => { if (confirm) { try { $('#wt-loading-box').css('display', 'block') await util.sleep(300); let res = await util.asyncHttp(_CONFIG_.apiBaseUrl + '/d' + (Math.floor(Math.random() * 3) + 1) +'00/downloadByAes?aes=' + encodeURIComponent(_CONFIG_.video.aes) + '&origin=' + location.origin + '&ap=' + 'R8CD9JUU4JThEJTg5JUU2JUE2JUI0JUU3JTlGJUFEJUU4JUE3JTg2JUU5JUEyJTkxY8DR4') res = JSON.parse(res.responseText) $('#wt-loading-box').css('display', 'none') if(res.errCode != 0){ util.showTips({ title: res.errMsg }) return; }else{ if(res.newToken) superVip._CONFIG_.user.token = res.newToken; _CONFIG_.user.role.use_download_num = res.useDownloadNum; _CONFIG_.video.downLoadUrl = res.data util.showDownLoadWindow(true, res.errMsg); GM_setValue('jsxl_user', _CONFIG_.user); } } catch (e) { console.log(e) $('#wt-loading-box').css('display', 'none') util.showTips({ title: e.message + '</br>' + location.href + '</br>获取下载链接失败' }) if(e.message.includes('明日再下载')){ _CONFIG_.user.stopDownload = true _CONFIG_.user.role.use_download_num = _CONFIG_.user.role.max_download_num GM_setValue('jsxl_user', _CONFIG_.user); } } } } }) } }) if (!_CONFIG_.user) { util.addLogin() util.findTargetElement('#wt-my').then(res => { setTimeout(() => { res.click() }, 2500) }) } $("#wt-set-box .user-box .user-info").on('click', function() { util.showTips({ title: '确定要跳转到插件官网吗?', doubt: true, success: (res) =>{ if(res){ location.href = superVip._CONFIG_.homeUrl } } }) }) //点击 通知 vipBox.find("#wt-my-notify").on("click", () => { if(_CONFIG_.showNotify){ $('#wt-notify-box').click() }else{ const notify = GM_getValue('notify','') if(notify && (notify.date == new Date().setHours(0,0,0,0))){ util.showNotify({ title: notify.msgInfo}) }else{ util.showNotify({ title: '还没有通知信息'}) } util.showAndHidTips('wt_my_notify','set',false) } }) $('#wt-set-box .logout').on('click', function(e) { util.showTips({ title: '您确定要退出登录吗?', doubt: true, success: (res) => { if (res) { util.logouted() $('#wt-mask-box').click() } } }) e.stopPropagation() }) //点击 隐藏控制器 vipBox.find("#wt-hid-box").on("click", () => { vipBox.css("transform","translate(125%, -50%)") $('#wt-left-show').css("transform","translate(0, -50%)") GM_setValue('91video_hid_controller',1) }) //点击 显示控制器 $('#wt-left-show').on('click',()=>{ $('#wt-left-show').css("transform","translate(-60px, -50%)") vipBox.css("transform","translate(0, -50%)") GM_setValue('91video_hid_controller','') }) //点击 设置界面遮罩 $('#wt-mask-box').on('click',()=>{ $('#wt-mask-box').css('display','none') $("#wt-set-box").removeClass('show-set-box') $("#wt-set-box").addClass('hid-set-box') $("#wt-download-box").removeClass('show-set-box'); $("#wt-download-box").addClass('hid-set-box') setTimeout(()=>{ $("#wt-set-box .line-box").css('display','none') $("#wt-set-box .user-box-container").css('display','none') _CONFIG_.myBtnOpen = false },500) }) //点击 设置/我的信息界面关闭 $("#wt-set-box .close").on("click", () => { $('#wt-mask-box').click() }) if(unsafeWindow.wt_91video_script > 1){ const controllerBoxId = '#wt-' + _CONFIG_.vipBoxId $(controllerBoxId).append(` <div class="num-error" style="position: absolute;top: 4px; left: 50%;transform: translateX(-50%);font-size: 10px;color: red;z-index: -1;"> ${unsafeWindow.wt_91video_script} </div> `) } } } return { start: () => { unsafeWindow.wt_91video_script = unsafeWindow.wt_91video_script? unsafeWindow.wt_91video_script ++: 1 _CONFIG_.user = GM_getValue('jsxl_user', ''); if(_CONFIG_.user){ if(_CONFIG_.user.login_date && (_CONFIG_.user.login_date != new Date().setHours(0,0,0,0))){ _CONFIG_.user = ''; GM_setValue('jsxl_user', ''); } } const targetConsumer = new BaseConsumer; targetConsumer.parse(); }, _CONFIG_ } })(); superVip.start(); } if(!unsafeWindow.jQuery){ const script = document.createElement('script'); script.src = 'https://cdnjs.cloudflare.com/ajax/libs/jquery/3.6.0/jquery.min.js'; script.onload = function() { init(unsafeWindow.jQuery) }; script.onerror = function(e) { alert('jquery初始化失败') }; document.head.appendChild(script); }else{ init(unsafeWindow.jQuery) }