在您安装前,Greasy Fork镜像 希望您知道此脚本包含可能不受欢迎的功能,也许会帮助脚本作者获利,而不能给你带来任何收益。
作者从这份脚本获得佣金,例如透过改写链接或提供优惠券代码以包含推荐或附属代码。
脚本作者的说明:
【此提示为GreasyFork代码规范要求含有查券功能的脚本必须添加,实际使用无任何强制跳转,代码可查,请知悉】
【❤️ 视频自动解析,体会拥有VIP的感觉❤️,适配PC+移动 】功能有:1、支持B站大会员番剧,全网独创自由选择自动解析接口;2、爱奇艺、腾讯、优酷、芒果等全网VIP视频免费解析去广告(免跳出观影特方便);3.B站多P下载;抖音、西瓜视频、快手无水印下载;4.淘宝、天猫、京东优惠券查询5.新增喜马拉雅有声书批量下载
目前为
// ==UserScript== // @name 【智狐】全网VIP视频解析无广告播放,支持B站大会员番剧、视频批量下载,全网独创自由选择自动解析接口|短视频无水印下载|淘宝、天猫、京东优惠券查询|更多功能持续更新中 // @namespace http://www.zhihupe.com/ // @version 1.28 // @author zhihu // @description 【❤️ 视频自动解析,体会拥有VIP的感觉❤️,适配PC+移动 】功能有:1、支持B站大会员番剧,全网独创自由选择自动解析接口;2、爱奇艺、腾讯、优酷、芒果等全网VIP视频免费解析去广告(免跳出观影特方便);3.B站多P下载;抖音、西瓜视频、快手无水印下载;4.淘宝、天猫、京东优惠券查询5.新增喜马拉雅有声书批量下载 // @icon https://www.zhihupe.com/favicon.ico // @require https://lf26-cdn-tos.bytecdntp.com/cdn/expire-1-M/crypto-js/4.1.1/crypto-js.min.js // @require https://lib.baomitu.com/echarts/4.6.0/echarts.min.js // @match *://laisoyiba.com/* // @match *://*.youku.com/v_* // @match *://*.iqiyi.com/v_* // @match *://*.iqiyi.com/w_* // @match *://*.iqiyi.com/a_* // @match *://v.qq.com/x/cover/* // @match *://v.qq.com/x/page/* // @match *://v.qq.com/tv/* // @match *://*.mgtv.com/b/* // @match *://*.bilibili.com/video/* // @match *://*.bilibili.com/bangumi/play/* // @match *://www.acfun.cn/bangumi/* // @match *://www.le.com/ptv/vplay/* // @match *://www.wasu.cn/Play/show/* // @match *://vip.1905.com/play/* // @match *://tv.sohu.com/v/* // @match *://film.sohu.com/album/* // @match *://v.pptv.com/show/* // @match *://m.v.qq.com/* // @match *://m.iqiyi.com/v_* // @match *://m.iqiyi.com/w_* // @match *://m.iqiyi.com/a_* // @match *://m.youku.com/alipay_video/* // @match *://m.youku.com/video/* // @match *://m.mgtv.com/b/* // @match *://m.bilibili.com/video/* // @match *://m.bilibili.com/anime/* // @match *://m.bilibili.com/bangumi/play/* // @match *://m.le.com/vplay_* // @match *://vip.1905.com/m/play/* // @match *://www.wasu.cn/wap/Play/show/* // @match *://m.tv.sohu.com/v.* // @match *://m.pptv.com/show/* // @match *://item.taobao.com/* // @match *://s.taobao.com/* // @match *://chaoshi.detail.tmall.com/* // @match *://*detail.tmall.com/* // @match *://*detail.tmall.hk/* // @match *://list.tmall.com/search_* // @match *://*item.jd.com/* // @match *://npcitem.jd.hk/* // @match *://*.yiyaojd.com/* // @match *://search.jd.com/Search* // @match *://www.ximalaya.com/* // @match *://tool.manmanbuy.com/* // @match *://*.douyin.com/video/* // @match *.kuaishou.com/short-video/* // @match *.kuaishou.com/video/* // @match *.ixigua.com/* // @connect tool.zhihupe.com // @connect 47.99.158.118 // @connect api.bilibili.com // @connect mobile.ximalaya.com // @connect v2.api.haodanku.com // @connect www.iesdouyin.com // @connect bijiatool-v2.manmanbuy.com // @grant GM_openInTab // @grant GM.openInTab // @grant GM_getValue // @grant GM.getValue // @grant GM_setValue // @grant GM.setValue // @grant GM_xmlhttpRequest // @grant GM.xmlHttpRequest // @grant GM_addStyle // @grant GM_deleteValue // @grant GM_setClipboard // @grant GM_download // @grant GM_registerMenuCommand // @grant GM_unregisterMenuCommand // @grant unsafeWindow // @run-at document-body // @license End-User License Agreement // @antifeature referral-link 【此提示为GreasyFork代码规范要求含有查券功能的脚本必须添加,实际使用无任何强制跳转,代码可查,请知悉】 // ==/UserScript== (function() { 'use strict'; //最终用户许可协议 End-User License Agreement // * Copyright (c) 2021-2022 zhihu. All Rights Reserved. // * Proprietary and Confidential. // * 该项目介绍、说明书、脚本代码、思路及其他相关 // 内容版权归作者所有,未经作者本人书面授权,禁 // 止任何单位或个人以任何形式、任何手段或通过任 // 何方式(净室工程、手工、图片、电子、机械、磁 // 性、化学、光学、声学或其它方式)抄袭、摘编、 // 编辑、修改、结集、出版、再版、转录、转载、爬 // 虫爬取、重制、仿制、复制、复写、复印、影印、 // 拷贝、刻录、建立镜像、粘贴、张贴、派发、录音、 // 用来创建派生作品、与其它任何资料进行合并、翻 // 译成任何电脑语言或以其他任何方式用于商业或公 // 共目的。 // * 该项目仅仅准许您善意的使用,其他任何行为都是 // 禁止的。 // * zhihu从未授权任何组织或个人使用本项目脚本 // 部分或全部代码创建作品。 const config ={ "playhref":window.location.href, "host":window.location.host, "UA":navigator.userAgent, "scriptInfo":GM_info.script, "hdapikey":"FF9529914C44", } const playList=[ {"name":"M3U8.TV","category":1,"url":"https://jx.m3u8.tv/jiexi/?url=", "showType":3}, {"name":"纯净/B站","category":1,"url":"https://z1.m1907.cn/?jx=", "showType":3}, {"name":"高速接口","category":1,"url":"https://jsap.attakids.com/?url=", "showType":3}, {"name":"综合/B站","category":1,"url":"https://vip.parwix.com:4433/player/?url=", "showType":3}, {"name":"OK解析","category":1,"url":"https://okjx.cc/?url=", "showType":3}, {"name":"618g","category":1,"url":"https://jx.618g.com/?url=", "showType":3}, {"name":"夜幕","category":1,"url":"https://www.yemu.xyz/?url=", "showType":3}, {"name":"乐多资源","category":1,"url":"https://api.leduotv.com/wp-api/ifr.php?isDp=1&vid=", "showType":3}, {"name":"爱豆","category":1,"url":"https://jx.aidouer.net/?url=", "showType":1}, {"name":"虾米","category":1,"url":"https://jx.xmflv.com/?url=", "showType":1}, {"name":"人人迷","category":1,"url":"https://jx.blbo.cc:4433/?url=", "showType":3}, {"name":"全民","category":1,"url":"https://jx.blbo.cc:4433/?url=", "showType":3}, {"name":"七哥","category":1,"url":"https://jx.mmkv.cn/tv.php?url=", "showType":3}, {"name":"冰豆","category":1,"url":"https://api.qianqi.net/vip/?url=", "showType":3}, {"name":"迪奥","category":1,"url":"https://123.1dior.cn/?url=", "showType":1}, {"name":"CK","category":1,"url":"https://www.ckplayer.vip/jiexi/?url=", "showType":1}, {"name":"游艺","category":1,"url":"https://api.u1o.net/?url=", "showType":1}, {"name":"LE","category":1,"url":"https://lecurl.cn/?url=", "showType":1}, {"name":"ckmov","category":1,"url":"https://www.ckmov.vip/api.php?url=", "showType":1}, {"name":"playerjy/B站","category":1,"url":"https://jx.playerjy.com/?url=", "showType":3}, {"name":"ccyjjd","category":1,"url":"https://ckmov.ccyjjd.com/ckmov/?url=", "showType":1}, {"name":"爱豆","category":1,"url":"https://jx.aidouer.net/?url=", "showType":1}, {"name":"诺诺","category":1,"url":"https://www.ckmov.com/?url=", "showType":1}, {"name":"H8","category":1,"url":"https://www.h8jx.com/jiexi.php?url=", "showType":1}, {"name":"BL","category":1,"url":"https://vip.bljiex.com/?v=", "showType":1}, {"name":"解析la","category":1,"url":"https://api.jiexi.la/?url=", "showType":1}, {"name":"MUTV","category":1,"url":"https://jiexi.janan.net/jiexi/?url=", "showType":1}, {"name":"MAO","category":1,"url":"https://www.mtosz.com/m3u8.php?url=", "showType":1}, {"name":"老板","category":1,"url":"https://vip.laobandq.com/jiexi.php?url=", "showType":1}, {"name":"盘古","category":1,"url":"https://www.pangujiexi.cc/jiexi.php?url=", "showType":1}, {"name":"盖世","category":1,"url":"https://www.gai4.com/?url=", "showType":1}, {"name":"小蒋","category":1,"url":"https://www.kpezp.cn/jlexi.php?url=", "showType":1}, {"name":"YiTV","category":1,"url":"https://jiexi.us/?url=", "showType":1}, {"name":"星空","category":1,"url":"http://60jx.com/?url=", "showType":1}, {"name":"0523","category":1,"url":"https://go.yh0523.cn/y.cy?url=", "showType":1}, {"name":"17云","category":1,"url":"https://www.1717yun.com/jx/ty.php?url=", "showType":1}, {"name":"4K","category":1,"url":"https://jx.4kdv.com/?url=", "showType":1}, {"name":"云析","category":1,"url":"https://jx.yparse.com/index.php?url=", "showType":1}, {"name":"8090","category":1,"url":"https://www.8090g.cn/?url=", "showType":1}, {"name":"江湖","category":1,"url":"https://api.jhdyw.vip/?url=", "showType":1}, {"name":"诺讯","category":1,"url":"https://www.nxflv.com/?url=", "showType":1}, {"name":"PM","category":1,"url":"https://www.playm3u8.cn/jiexi.php?url=", "showType":1}, {"name":"奇米","category":1,"url":"https://qimihe.com/?url=", "showType":1}, {"name":"思云","category":1,"url":"https://jx.ap2p.cn/?url=", "showType":1}, {"name":"听乐","category":1,"url":"https://jx.dj6u.com/?url=", "showType":1}, {"name":"aijx","category":1,"url":"https://jiexi.t7g.cn/?url=", "showType":1}, {"name":"52","category":1,"url":"https://vip.52jiexi.top/?url=", "showType":1}, {"name":"黑米","category":1,"url":"https://www.myxin.top/jx/api/?url=", "showType":1}, {"name":"豪华啦","category":1,"url":"https://api.lhh.la/vip/?url=", "showType":1}, {"name":"凉城","category":1,"url":"https://jx.mw0.cc/?url=", "showType":1}, {"name":"33t","category":1,"url":"https://www.33tn.cn/?url=", "showType":1}, {"name":"180","category":1,"url":"https://jx.000180.top/jx/?url=", "showType":1}, {"name":"无名","category":1,"url":"https://www.administratorw.com/video.php?url=", "showType":1}, {"name":"黑云","category":1,"url":"https://jiexi.380k.com/?url=", "showType":1}, {"name":"九八","category":1,"url":"https://jx.youyitv.com/?url=", "showType":1}, {"name":"综合线路","category":2,"url":"https://laisoyiba.com/mov/s/?sv=3&url=", "showType":1}, {"name":"纯净/B站","category":2,"url":"https://z1.m1907.cn/?jx=", "showType":1}, {"name":"高速接口","category":2,"url":"https://jsap.attakids.com/?url=", "showType":1}, {"name":"综合/B站1","category":2,"url":"https://vip.parwix.com:4433/player/?url=", "showType":1}, {"name":"OK解析","category":2,"url":"https://okjx.cc/?url=", "showType":1}, {"name":"夜幕","category":2,"url":"https://www.yemu.xyz/?url=", "showType":1}, {"name":"虾米","category":2,"url":"https://jx.xmflv.com/?url=", "showType":1}, {"name":"全民","category":2,"url":"https://jx.quanmingjiexi.com/?url=", "showType":1}, ]; var author = config.scriptInfo.author; var commonFunction = { Toast:function(msg, duration = 3000){ var m = document.createElement('div'); m.innerHTML = msg; m.setAttribute('id','msg'); m.style.cssText = "max-width:60%;min-width: 150px;padding:0 14px;min-height: 40px;color: rgb(255, 255, 255);line-height: 40px;text-align: center;border-radius: 4px;position: fixed;top: 50%;left: 50%;transform: translate(-50%, -50%);z-index: 9999999999;background: rgba(0, 0, 0,.7);font-size: 16px;"; document.body.appendChild(m); setTimeout(() => { var d = 0.5; m.style.webkitTransition = '-webkit-transform ' + d + 's ease-in, opacity ' + d + 's ease-in'; m.style.opacity = '0'; setTimeout(() => { document.body.removeChild(document.querySelector("#msg")) }, d * 1000); }, duration); }, //兼容 Tampermonkey | Violentmonkey | Greasymonkey 4.0+ GMopenInTab:function(url, open_in_background) { if (typeof GM_openInTab === "function") { GM_openInTab(url, open_in_background); } else { GM.openInTab(url, open_in_background); } }, //兼容 Tampermonkey | Violentmonkey | Greasymonkey 4.0+ GMgetValue:function(name, value) { if (typeof GM_getValue === "function") { return GM_getValue(name, value); } else { return GM.getValue(name, value); } }, //兼容 Tampermonkey | Violentmonkey | Greasymonkey 4.0+ GMsetValue:function(name, value) { if (typeof GM_setValue === "function") { GM_setValue(name, value); } else { GM.setValue(name, value); } }, //兼容 Tampermonkey | Violentmonkey | Greasymonkey 4.0+ GMxmlhttpRequest:function(obj) { if (typeof GM_xmlhttpRequest === "function") { GM_xmlhttpRequest(obj); } else { GM.xmlhttpRequest(obj); } }, setItem:function(name, Value) { localStorage.setItem(name, Value); }, getItem:function(name) { let StorageValue = localStorage.getItem(name); return StorageValue; }, removeItem:function(name) { localStorage.removeItem(name); }, GMaddStyle:function(data,id=null) { var addStyle = document.createElement('style'); addStyle.textContent = data; addStyle.type = 'text/css'; addStyle.id = id; var doc = document.head || document.documentElement; doc.appendChild(addStyle); }, GMaddScript:function(data) { let script = document.createElement('script'); script.src = data; var docu = document.head || document.documentElement; docu.appendChild(script); }, GMaddlink:function(data) { let mylink = document.createElement('link'); mylink.href = data; mylink.rel = 'stylesheet'; var docl = document.head || document.documentElement; docl.appendChild(mylink); }, GMopenInTab:function(url, open_in_background) { if (typeof GM_openInTab === "function") { GM_openInTab(url, open_in_background); } else { GM.openInTab(url, open_in_background); } }, sleep:function(time) { return new Promise(resolve => setTimeout(resolve, time)); }, Commonsetinterval:function(data){ var Count; var num =""; return new Promise(function(resolve, reject){ Count = setInterval(function() { var node = document.querySelector(data); num++; if(node != null ){ resolve(node); clearInterval(Count); } if(num ==100){ clearInterval(Count); } console.log(node) },200); }); }, Videosetinterval:function(data){ var Count; return new Promise(function(resolve, reject){ Count = setInterval(function() { var node = document.querySelector(data).children; if(node != null ){ resolve(Count); console.log(node) } console.log(node) },200); }); }, menusetting:function(){ //初始化脚本设置 if(commonFunction.GMgetValue("videosetting")==null){ commonFunction.GMsetValue("videosetting",1); } if(commonFunction.GMgetValue("couponsetting")==null){ commonFunction.GMsetValue("couponsetting",1); } if(commonFunction.GMgetValue("historysetting")==null){ commonFunction.GMsetValue("historysetting",1); } if(commonFunction.GMgetValue("Shortvideosetting")==null){ commonFunction.GMsetValue("Shortvideosetting",1); } if(commonFunction.GMgetValue("Bilibilisetting")==null){ commonFunction.GMsetValue("Bilibilisetting",1); } if(commonFunction.GMgetValue("Ximalayasetting")==null){ commonFunction.GMsetValue("Ximalayasetting",1); } }, IsPC:function() { var userAgentInfo = config.UA; var Agents = ["Android", "iPhone","SymbianOS", "Windows Phone", "iPad", "iPod"]; var flag = true; for (let i = 0; i < Agents.length; i++) { if (userAgentInfo.indexOf(Agents[i]) > 0) { flag = false; break; } } return flag; }, IsWap:function(){ var com = null; if(config.host.indexOf('item.') > -1) { com = "pc"; }else if (config.host.indexOf('m.') > -1||config.playhref.indexOf('/m/') > -1||config.playhref.indexOf('/wap/') > -1) { com = "wap"; }else { com = "pc"; } return com }, Getgoodid:function(data){ var reg = new RegExp("(^|&)" + data + "=([^&]*)(&|$)"); var s = window.location.search.substr(1).match(reg); if (s != null) { return s[2]; } return ""; }, geturlid:function(url) { var id =""; if (url.indexOf("?") != -1) { url = url.split("?")[0] } if (url.indexOf("#") != -1) { url = url.split("#")[0] } var text = url.split("/"); id = text[text.length - 1]; id = id.replace(".html", ""); return id }, request:function(method,url,headers,data=null){ return new Promise(function(resolve, reject){ commonFunction.GMxmlhttpRequest({ url: url, method: method, data:data, headers:headers, onload: function(res) { var status = res.status; var responseText = res.responseText; if(status==200||status=='200'){ resolve({"result":"success", "data":responseText}); }else{ reject({"result":"error", "data":null}); } } }); }) }, open:function(data){ var main = document.createElement('div'); var width = data.area[0]; var height = data.area[1]; var margintop = height/2; var marginleft = width/2; var style = "z-index: 999999998;width: "+width+"px;height:"+height+"px;position: fixed;top: 50%;left: 50%;margin-left:-"+marginleft+"px;margin-top:-"+margintop+"px;" var btnHTML = '<a class="zhihu-layer-btn0">'+data.btn[0]+'</a><a class="zhihu-layer-btn1">'+data.btn[1]+'</a>'; main.innerHTML = '<div class="zhihu-layer-title" style="cursor: move;">'+data.title+'</div><div class="zhihu-layer-content" >'+data.content+'</div><span class="zhihu-layer-setwin"><a class="zhihu-layer-ico zhihu-layer-close1" href="javascript:;"></a></span><div class="zhihu-layer-btn zhihu-layer-btn-c">'+btnHTML+'</div>'; main.setAttribute('id',data.id); main.setAttribute('style',style); main.setAttribute('class',"zhihu-layer-page"); document.body.appendChild(main); var shade = document.createElement('div'); shade.setAttribute('style',"z-index: 999999997;background-color: rgb(0, 0, 0);opacity: 0.3;"); shade.setAttribute('class',"zhihu-layer-shade"); shade.setAttribute('id',"zhihu-layer-shade"); shade.innerHTML ='' document.body.appendChild(shade); var css = ` ::-webkit-scrollbar { height: 6px; width: 6px; } ::-webkit-scrollbar-track { background: transparent; width: 6px; } ::-webkit-scrollbar-thumb { background-color: #54be99; border-radius: 4px; -webkit-transition: all 1s; transition: all 1s; width: 6px; } ::-webkit-scrollbar-corner { background-color: #54be99; } li { list-style: none; } .zhihu-form-label, .zhihu-form-select, .zhihu-input-block, .zhihu-input-inline{ position: relative; } .zhihu-layer-shade { top: 0; left: 0; width: 100%; height: 100%; position: fixed; _height: expression(document.body.offsetHeight+"px"); } .zhihu-layer-page{ margin: 0; padding: 0; background-color: #fff; border-radius: 10px; box-shadow: 1px 1px 50px rgba(0,0,0,.4); font-family: PingFang SC, HarmonyOS_Regular, Helvetica Neue, Microsoft YaHei, sans-serif; } .zhihu-layer-title{ padding: 0 80px 0 20px; height: 50px; line-height: 50px; border-bottom: 1px solid #F0F0F0; border-radius: 2px 2px 0 0; font-size: 14px; color: #333; overflow: visible; text-overflow: ellipsis; white-space: nowrap; font-weight: bold; } .zhihu-layer-setwin { position: absolute; right: 15px; top: 17px; font-size: 0; line-height: initial; } .zhihu-layer-setwin .zhihu-layer-close1 { background-position: 1px -40px; cursor: pointer; } .zhihu-layer-setwin a { position: relative; width: 16px; height: 16px; margin-left: 10px; font-size: 12px; _overflow: hidden; } .zhihu-layer-btn a, .zhihu-layer-setwin a { display: inline-block; vertical-align: top; } .zhihu-layer-ico { background: url(https://www.layuicdn.com/layui/css/modules/layer/default/icon.png) no-repeat; } .zhihu-layer-btn { text-align: right; padding: 10px 15px 12px; pointer-events: auto; user-select: none; -webkit-user-select: none; } .zhihu-layer-btn-c { text-align: center; } .zhihu-layer-btn a { height: 28px; line-height: 28px; margin: 5px 5px 0; padding: 0 15px; border: 1px solid #dedede; background-color: #fff; color: #333; border-radius: 4px; font-weight: 400; cursor: pointer; text-decoration: none; } .zhihu-layer-btn1 { border-color: #54be99!important; background-color: #54be99!important; color: #fff!important; } .zhihu-form-item { margin-bottom: 5px; clear: both; } .zhihu-form-label { float: left; display: block; padding: 9px 15px; width: 80px; font-weight: 400; line-height: 20px; text-align: right; box-sizing: content-box; } .zhihu-input-inline { display: inline-block; vertical-align: middle; width: 190px; margin-right: 10px; } .zhihu-input, .zhihu-select, .zhihu-textarea { height: 38px; line-height: 1.3; border-width: 1px; border-style: solid; border-color: #eee; display: block; width: 100%; padding-left: 10px; background-color: #fff; color: rgba(0,0,0,.85); border-radius: 2px; outline: 0; -webkit-appearance: none; transition: all .3s; -webkit-transition: all .3s; box-sizing: border-box; } .zhihu-input-block { min-height: auto; margin-left: 110px; } .zhihu-input-block p { font-size: 12px; line-height: 22px; } .zhihu-form { display: flex; margin-top: 20px; } `; commonFunction.GMaddStyle(css,"open"); // await commonFunction.sleep(1000); //获取表单对象 var zhihuform = document.querySelector('.zhihu-form'); //保存按钮点击事件 document.querySelector('.zhihu-layer-btn1').addEventListener('click',function() { data.btn1(zhihuform); document.body.removeChild(document.querySelector(".zhihu-layer-page")); document.body.removeChild(document.querySelector("#zhihu-layer-shade")); document.getElementsByTagName("head").item(0).removeChild(document.getElementById("open")); }) //取消钮点击事件 document.querySelector(".zhihu-layer-btn0").addEventListener('click',function() { document.body.removeChild(document.querySelector(".zhihu-layer-page")); document.body.removeChild(document.querySelector("#zhihu-layer-shade")); document.getElementsByTagName("head").item(0).removeChild(document.getElementById("open")); }) //关闭钮点击事件 document.querySelector(".zhihu-layer-close1").addEventListener('click',function() { document.body.removeChild(document.querySelector(".zhihu-layer-page")); document.body.removeChild(document.querySelector("#zhihu-layer-shade")); document.getElementsByTagName("head").item(0).removeChild(document.getElementById("open")); }) }, tab:async function(data){ var main = document.createElement('div'); var width = data.area[0]; var height = data.area[1]; var margintop = height/2; var marginleft = width/2; var style = "z-index: 999999998;width: "+width+"px;height:"+height+"px;position: fixed;top: 50%;left: 50%;margin-left:-"+marginleft+"px;margin-top:-"+margintop+"px;" var titleHTML =""; var contentHTML = ""; var btnHTML = '<a class="zhihu-layer-btn0">'+data.btn[0]+'</a><a class="zhihu-layer-btn1">'+data.btn[1]+'</a>' for (let i = 0; i < data.tab.length; i++) { if(i === 0 ){ titleHTML +='<span class="tab-title zhihu-this">'+data.tab[i].title+'</span>'; contentHTML += '<li class="zhihu-layer-tabli zhihu-this">'+data.tab[i].content+'</li>'; }else{ titleHTML +='<span class="tab-title">'+data.tab[i].title+'</span>'; contentHTML += '<li class="zhihu-layer-tabli ">'+data.tab[i].content+'</li>'; } } main.innerHTML = '<div class="zhihu-layer-title" style="cursor: move;">'+titleHTML+'</div><div class="zhihu-layer-content" ><ul class="zhihu-layer-tabmain">'+contentHTML+'</ul></div><span class="zhihu-layer-setwin"><a class="zhihu-layer-ico zhihu-layer-close1" href="javascript:;"></a></span><div class="zhihu-layer-btn zhihu-layer-btn-c">'+btnHTML+'</div>'; main.setAttribute('id',data.id); main.setAttribute('style',style); main.setAttribute('class',"zhihu-layer-tab"); document.body.appendChild(main); var tabtitle = document.getElementsByClassName('tab-title'); for (let i = 0; i < tabtitle.length; i++) { let tabli = document.getElementsByClassName('zhihu-layer-tabli')[i]; tabtitle[i].addEventListener('click',function() { document.querySelector(".zhihu-layer-title>.zhihu-this").classList.remove("zhihu-this"); this.classList.add("zhihu-this"); document.querySelector(".zhihu-layer-tabmain>.zhihu-this").classList.remove("zhihu-this"); tabli.classList.add("zhihu-this"); }); } var shade = document.createElement('div'); shade.setAttribute('style',"z-index: 999999997;background-color: rgb(0, 0, 0);opacity: 0.3;"); shade.setAttribute('class',"zhihu-layer-shade"); shade.setAttribute('id',""); shade.innerHTML ='' document.body.appendChild(shade); var css = ` ::-webkit-scrollbar { height: 6px; width: 6px; } ::-webkit-scrollbar-track { background: transparent; width: 6px; } ::-webkit-scrollbar-thumb { background-color: #54be99; border-radius: 4px; -webkit-transition: all 1s; transition: all 1s; width: 6px; } ::-webkit-scrollbar-corner { background-color: #54be99; } li { list-style: none; } .zhihu-form-label, .zhihu-form-select, .zhihu-input-block, .zhihu-input-inline{ position: relative; } .zhihu-layer-shade { top: 0; left: 0; width: 100%; height: 100%; position: fixed; _height: expression(document.body.offsetHeight+"px"); } .zhihu-layer-tab{ margin: 0; padding: 0; background-color: #fff; border-radius: 10px; box-shadow: 1px 1px 50px rgba(0,0,0,.4); font-family: PingFang SC, HarmonyOS_Regular, Helvetica Neue, Microsoft YaHei, sans-serif; } .zhihu-layer-title{ padding: 0 80px 0 20px; height: 50px; line-height: 50px; border-bottom: 1px solid #F0F0F0; border-radius: 2px 2px 0 0; font-size: 14px; color: #333; padding-left: 0; overflow: visible; text-overflow: ellipsis; white-space: nowrap; } .zhihu-layer-title span { position: relative; float: left; min-width: 80px; max-width: 300px; padding: 0 20px; text-align: center; overflow: hidden; cursor: pointer; font-weight: bold; color: #000; } .zhihu-layer-title span:first-child { border-left: none; } .zhihu-layer-title span.zhihu-this { height: 51px; border-left: 1px solid #eee; border-right: 1px solid #eee; background-color: #fff; z-index: 10; } .zhihu-layer-title span:first-child.zhihu-this { border-radius: 10px 0 0 0; } .zhihu-layer-content { position: relative; overflow: hidden; height:290px; } .zhihu-layer-tabmain { line-height: 24px; clear: both; padding: 0; margin: 0; } .zhihu-layer-tabli{ display:none; height: 100%; } .zhihu-layer-tabmain .zhihu-this{ display:block; } .zhihu-layer-setwin { position: absolute; right: 15px; top: 17px; font-size: 0; line-height: initial; } .zhihu-layer-setwin .zhihu-layer-close1 { background-position: 1px -40px; cursor: pointer; } .zhihu-layer-setwin a { position: relative; width: 16px; height: 16px; margin-left: 10px; font-size: 12px; _overflow: hidden; } .zhihu-layer-btn a, .zhihu-layer-setwin a { display: inline-block; vertical-align: top; } .zhihu-layer-ico { background: url(https://www.layuicdn.com/layui/css/modules/layer/default/icon.png) no-repeat; } .zhihu-layer-btn { text-align: right; padding: 10px 15px 12px; pointer-events: auto; user-select: none; -webkit-user-select: none; } .zhihu-layer-btn-c { text-align: center; } .zhihu-layer-btn a { height: 28px; line-height: 28px; margin: 5px 5px 0; padding: 0 15px; border: 1px solid #dedede; background-color: #fff; color: #333; border-radius: 4px; font-weight: 400; cursor: pointer; text-decoration: none; } .zhihu-layer-btn1 { border-color: #54be99!important; background-color: #54be99!important; color: #fff!important; } .zhihu-form-item { margin-bottom: 15px; clear: both; } .zhihu-form-label { float: left; display: block; padding: 9px 15px; width: 80px; font-weight: 400; line-height: 20px; text-align: right; } .zhihu-input-block { margin-left: 110px; min-height: 36px; width: 190px; } .zhihu-form input[type=checkbox], .zhihu-form input[type=radio], .zhihu-form select { display: none; } .zhihu-form-switch { position: relative; height: 22px; line-height: 22px; min-width: 35px; padding: 0 5px; margin-top: 8px; border: 1px solid #d2d2d2; border-radius: 20px; cursor: pointer; background-color: #fff; -webkit-transition: .1s linear; transition: .1s linear; } .zhihu-form-checkbox, .zhihu-form-checkbox *, .zhihu-form-switch { display: inline-block; vertical-align: middle; } .zhihu-unselect { -moz-user-select: none; -webkit-user-select: none; -ms-user-select: none; } .zhihu-form-switch em { position: relative; top: 0; width: 25px; margin-left: 21px; padding: 0!important; text-align: center!important; color: #999!important; font-style: normal!important; font-size: 12px; } .zhihu-form-switch i { position: absolute; left: 5px; top: 3px; width: 16px; height: 16px; border-radius: 20px; background-color: #d2d2d2; -webkit-transition: .1s linear; transition: .1s linear; } .zhihu-form-onswitch { border-color: #54be99; background-color: #54be99; } .zhihu-form-onswitch em { margin-left: 5px; margin-right: 21px; color: #fff!important; } .zhihu-form-onswitch i { left: 100%; margin-left: -21px; background-color: #fff; } .zhihu-form-select .zhihu-input { padding-right: 30px; cursor: pointer; } .zhihu-input, .zhihu-textarea { display: block; width: 100%; padding-left: 10px; } .zhihu-input, .zhihu-select, .zhihu-textarea { height: 38px; line-height: 1.3; border-width: 1px; border-style: solid; background-color: #fff; color: rgba(0,0,0,.85); border-radius: 2px; } .zhihu-btn, .zhihu-input, .zhihu-select, .zhihu-textarea, .zhihu-upload-button { outline: 0; -webkit-appearance: none; transition: all .3s; -webkit-transition: all .3s; box-sizing: border-box; border-color: #eee; } .zhihu-form-select .zhihu-edge { position: absolute; right: 10px; top: 50%; margin-top: -3px; cursor: pointer; border-width: 6px; border-top-color: #c2c2c2; border-top-style: solid; transition: all .3s; -webkit-transition: all .3s; } .zhihu-edge { width: 0; border-width: 6px; border-style: dashed; border-color: transparent; } .zhihu-edge { display: inline-block; } .zhihu-form-selected .zhihu-edge { margin-top: -9px; -webkit-transform: rotate(180deg); transform: rotate(180deg); } .zhihu-anim { -webkit-animation-duration: .3s; -webkit-animation-fill-mode: both; animation-duration: .3s; animation-fill-mode: both; } .zhihu-form-select dl, .zhihu-panel { box-shadow: 1px 1px 4px rgb(0 0 0 / 8%); } .zhihu-form-select dl { display: none; position: absolute; left: 0; top: 42px; padding: 5px 0; z-index: 899; min-width: 100%; border: 1px solid #eee; max-height: 300px; overflow-y: auto; background-color: #fff; border-radius: 2px; box-sizing: border-box; margin: 0; } .zhihu-form-selected dl { display: block; } .zhihu-form-select dl dd, .zhihu-form-select dl dt { padding: 0 10px; line-height: 36px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; margin: 0; } .zhihu-form-select dl dd { cursor: pointer; } .zhihu-form-select dl dd.zhihu-select-tips { padding-left: 10px!important; color: #999; } .zhihu-form-select dl dd.zhihu-this { background-color: #5FB878; color: #fff; } `; commonFunction.GMaddStyle(css,"tab"); await commonFunction.sleep(1000); //获取表单对象 var zhihuform = document.querySelector('.zhihu-form'); //保存按钮点击事件 document.querySelector('.zhihu-layer-btn1').addEventListener('click',function() { data.btn1(zhihuform); document.body.removeChild(document.querySelector(".zhihu-layer-tab")); document.body.removeChild(document.querySelector(".zhihu-layer-shade")); document.getElementsByTagName("head").item(0).removeChild(document.getElementById("tab")); }) //取消钮点击事件 document.querySelector(".zhihu-layer-btn0").addEventListener('click',function() { document.body.removeChild(document.querySelector(".zhihu-layer-tab")); document.body.removeChild(document.querySelector(".zhihu-layer-shade")); document.getElementsByTagName("head").item(0).removeChild(document.getElementById("tab")); }) //关闭钮点击事件 document.querySelector(".zhihu-layer-close1").addEventListener('click',function() { document.body.removeChild(document.querySelector(".zhihu-layer-tab")); document.body.removeChild(document.querySelector(".zhihu-layer-shade")); document.getElementsByTagName("head").item(0).removeChild(document.getElementById("tab")); }) //开关添加开始 var zhihuinput = zhihuform.getElementsByTagName('input'); for (let i = 0; i < zhihuinput.length; i++) { let type = zhihuinput[i].getAttribute("type"); if(type =="checkbox"){ if(zhihuinput[i].checked){ zhihuinput[i].insertAdjacentHTML('afterEnd', '<div class="zhihu-unselect zhihu-form-switch zhihu-form-onswitch"><em>ON</em><i></i></div>'); }else{ zhihuinput[i].insertAdjacentHTML('afterEnd', '<div class="zhihu-unselect zhihu-form-switch "><em>OFF</em><i></i></div>'); } } } //开关添加结束 //开关点击事件开始 var zhihuswitch = document.getElementsByClassName('zhihu-form-switch'); for (let i = 0; i < zhihuinput.length; i++) { zhihuswitch[i].addEventListener('click',function() { let onswitch = this.getAttribute("class"); if(onswitch.indexOf("zhihu-form-onswitch")!=-1){ this.parentNode.querySelector('input').removeAttribute("checked"); this.classList.remove("zhihu-form-onswitch"); this.innerHTML ="<em>OFF</em><i></i>" }else{ this.parentNode.querySelector('input').setAttribute("checked",true); this.classList.add("zhihu-form-onswitch"); this.innerHTML ="<em>ON</em><i></i>" } }) } //开关点击事件结束 //下拉框添加开始 var zhihuselect = zhihuform.getElementsByTagName('select'); for (let i = 0; i < zhihuselect.length; i++) { let optionHtml =''; let zhihuoption = zhihuselect[i].getElementsByTagName('option'); if(zhihuselect[i].selectedIndex < 0){ var Index = 0 }else{ Index = zhihuselect[i].selectedIndex; } let selecttext = zhihuselect[i].options[Index].text; var selectvalue = zhihuselect[i].options[Index].value; for (let l = 0; l < zhihuoption.length; l++) { let optionText = zhihuoption[l].innerText; let optionvalue = zhihuoption[l].value; if(optionvalue == selectvalue){ optionHtml += '<dd zhihu-value="'+optionvalue+'" class="zhihu-select-tips zhihu-this">'+optionText+'</dd>' }else{ optionHtml += '<dd zhihu-value="'+optionvalue+'" class="">'+optionText+'</dd>' } } var selectHtml = '<div class="zhihu-unselect zhihu-form-select"><div class="zhihu-select-title"><input type="text" placeholder="直接选择或搜索选择" value="'+selecttext+'" readonly="" class="zhihu-input zhihu-unselect"><i class="zhihu-edge"></i></div><dl class="zhihu-anim" style="">'+optionHtml+'</dl></div>'; zhihuselect[i].insertAdjacentHTML('afterEnd',selectHtml); } //下拉框添加结束 //下拉框操作事件开始 var zhihuunselect = document.getElementsByClassName("zhihu-form-select"); for (let i = 0; i < zhihuunselect.length; i++) { //下拉框点击事件 zhihuunselect[i].addEventListener('click',function() { var selected = this.getAttribute("class"); if(selected.indexOf("zhihu-form-selected")!=-1){ this.classList.remove("zhihu-form-selected"); }else{ this.classList.add("zhihu-form-selected"); }; },false); //下拉框选择事件 var zhihudd = zhihuunselect[i].getElementsByTagName('dd'); for (let l = 0; l < zhihudd.length; l++) { zhihudd[l].addEventListener('click',function() { var a = zhihuunselect[i].querySelector('.zhihu-this'); if(a){ a.classList.remove("zhihu-this"); a.classList.remove("zhihu-select-tips"); } this.classList.add("zhihu-this"); this.classList.add("zhihu-select-tips"); console.log(this.getAttribute("zhihu-value")); console.log(zhihuunselect[i].parentNode.querySelector('select')) zhihuunselect[i].parentNode.querySelector('select').value = this.getAttribute("zhihu-value"); zhihuunselect[i].parentNode.querySelector('input').setAttribute("value",this.innerText); }); }; } //下拉框操作事件结束 }, } //-------------------------------------------------------------- var ControllerVideo = { //播放节点 Playid:function(){ var PlayidList = [ { url:"v.qq.com", node:"#mod_player"}, { url:"www.iqiyi.com", node:"#flashbox"}, { url:"v.youku.com", node:"#player"}, { url:"w.mgtv.com", node:"#mgtv-player-wrap"}, { url:"www.mgtv.com", node:"#mgtv-player-wrap"}, { url:"tv.sohu.com", node:"#player"}, { url:"film.sohu.com", node:"#playerWrap"}, { url:"www.le.com", node:"#le_playbox"}, { url:"v.pptv.com", node:"#pptv_playpage_box"}, { url:"vip.pptv.com", node:".w-video"}, { url:"www.wasu.cn", node:"#flashContent"}, { url:"www.bilibili.com", node:"#player_module"}, { url:"vip.1905.com", node:"#player"}, { url:"m.v.qq.com", node:"#player"}, { url:"m.youku.com", node:"#player"}, { url:"m.iqiyi.com", node:".m-video-player-wrap"}, { url:"m.mgtv.com", node:".video-area"}, { url:"m.bilibili.com", node:"#bofqi"}, { url:"m.le.com", node:"#j-player"}, { url:"m.tv.sohu.com", node:".player"}, { url:"m.pptv.com", node:".pp-details-video"}, ]; var Playid = null; for(let i in PlayidList) { //获得窗口ID if (PlayidList[i].url == config.host) { if(config.playhref.indexOf("www.wasu.cn/wap/Play")!=-1){ Playid ="#pop" }else if(PlayidList[i].url == "v.qq.com"){ var player = document.querySelector(".player_side_bd"); console.log(player) if(player!=null){ Playid = "#mod_player"; }else{ Playid = "#player-container" } }else{ Playid = PlayidList[i].node; } return Playid break; } } if(!Playid){ return; } }, //---------------------------------------------------------------------- //接口列表 Videolist:function(f){ var ListHtml={ "Insidehtml":"", "selecthtml":"", "mobhtml":"", "Outsidehtml":"", }; //----------------------------- let v = commonFunction.GMgetValue("userplayurl"); // GM_deleteValue("userplayurl"); if(v){ var e = v.concat(f); }else{ e = f; } console.log(f) console.log(e) for (let i = 0; i < e.length; i++) { if (e[i].category == 1) { ListHtml.Insidehtml += "<span class='jiexi inside' id='Inside_" + i + "' title='" + e[i].name + "' data-index='" + i + "' data-url='" + e[i].url + "'>" + e[i].name + "</span>"; ListHtml.selecthtml += "<option value='" +i + "' name='select' data-url='" + e[i].url + "'>" + e[i].name + "</option>" if (e[i].showType == 3) { ListHtml.mobhtml += "<span class='mob-jiexi' id='mob_" + i + "' title='" + e[i].name + "' data-index='" + i + "' data-url='" + e[i].url + "'>" + e[i].name + "</span>"; } } else { ListHtml.Outsidehtml += "<span class='jiexi outside 'title='" + e[i].name + "' data-index='" + i + "' data-url='" + e[i].url + "'>" + e[i].name + "</span>"; } } //----------------------------- return ListHtml }, //增加接口列表 Videoaddlist:function(){ var addListHtml=""; //----------------------------- let e = commonFunction.GMgetValue("userplayurl"); console.log(e); if(e != null&&e != ""&&e != undefined){ for (let i = 0; i < e.length; i++) { if(e[i].category == 1){ addListHtml += '<li><span>'+e[i].name+'</span><span>内部播放</span><span class="urllist">'+e[i].url+'</span><span class="delurl" data-id='+i+'>删除</span></li>'; }else if(e[i].category == 2){ addListHtml += '<li><span>'+e[i].name+'</span><span>跳转播放</span><span class="urllist">'+e[i].url+'</span><span class="delurl" data-id='+i+'>删除</span></li>'; }else{ continue; } } }else{ addListHtml = '<p style="text-align: center;margin: 20px 0;">暂无数据</p>' } //----------------------------- return addListHtml }, //---------------------------------------------------------------------- //电脑端 addbtn:async function(){ await commonFunction.sleep(1000); var css = `body, html { font: 14px/1.5 "PingFang SC","微软雅黑","Microsoft YaHei",Helvetica,"Helvetica Neue",Tahoma,Arial,sans-serif; color: #1c1f21; height: 100%; } .elevator { position: fixed; padding: 0 16px; top: 55%; margin-top: -140px; left: 0; z-index: 999999996; background: rgb(134 134 134 / 40%); box-shadow: 1px 1px 8px 1px rgb(98 99 99 / 34%); border-radius: 0 8px 8px 0; } .elevator a { position: relative; display: block; width: 26px; height: 56px; font-size: 22px; line-height: 20px; color: #b5b9bc; box-sizing: border-box; text-align: center; } .elevator a+a:after { position: absolute; top: 0; left: 50%; margin-left: -12px; content: ''; width: 24px; border: 1px solid #F3F5F7; } .elevator a:hover { color: #14191e; } .elevator svg { font-size: 24px; line-height: 56px; color: #199b6d; width: 28px; height: 28px; margin: 14px 0; } .elevator svg:hover { color: #14191e; } .elevator a span { display: none; padding: 14px 0; font-size: 12px; color: #fff; line-height: 14px; } .elevator a:hover svg { display: none; } .elevator a:hover span { display: inline-block; } .jiexi{ padding: 8px 10px; background: #e5e5e5a3; font-size: 12px; border-radius: 4px; margin:0 8px 10px 8px; color: #505050; display: inline-block; width: 80px; text-align: center; } .jiexiselect{ color: #fff; background:#54be99; } .zhihu-scan{ width:144px; display:inline-block; text-align: center; margin-left:8px; } .zhihu-scan img{ width: 140px; margin: 0 5px 10px 5px; } .zhihu-scan h1{ font-size: 18px; font-weight: bold; margin: 0px 0 20px 0; } .zhihu-scan p{ margin: 0; color: #666; font-size: 12px; line-height: 26px; } .addlist{ margin: 15px 0 0 0; padding: 0; } .addlist li{ font-size: 14px; color: #333; line-height:36px; height: 36px; } .addlist li span{ width: 100px; display: inline-block; text-align: center; overflow: hidden; font-size: 14px; color: #333; white-space:nowrap; text-overflow:ellipsis; } .addlist li .urllist{ width: 214px; } ::-webkit-input-placeholder{color:#999;font-size:12px;line-height:16px} :-moz-placeholder{color:#999;font-size:12px;line-height:16px} ::-moz-placeholder{color:#999;font-size:12px;line-height:16px} :-ms-input-placeholder{color:#999;font-size:12px;line-height:16px} `; commonFunction.GMaddStyle(css); ControllerVideo.CheckAutoplay(); var btnhtml = '<div class="elevator" id=""><a href="javascript:;" class="elevator-msg" id="PlayMain"><svg t="1651763850342" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="2320" width="200" height="200"><path d="M661.333333 665.6l51.2 12.8 42.666667-72.533333-34.133333-38.4c4.266667-21.333333 4.266667-38.4 4.266666-55.466667s0-34.133333-4.266666-51.2l34.133333-38.4-42.666667-72.533333-51.2 12.8c-25.6-21.333333-55.466667-42.666667-89.6-51.2L554.666667 256h-85.333334l-17.066666 51.2c-34.133333 8.533333-64 25.6-89.6 51.2l-51.2-12.8-42.666667 72.533333 34.133333 38.4c-4.266667 21.333333-4.266667 38.4-4.266666 55.466667s0 34.133333 4.266666 51.2l-34.133333 38.4 42.666667 72.533333 51.2-12.8c25.6 21.333333 55.466667 42.666667 89.6 51.2L469.333333 768h85.333334l17.066666-51.2c34.133333-8.533333 64-25.6 89.6-51.2z m38.4 81.066667c-21.333333 17.066667-51.2 34.133333-76.8 42.666666L597.333333 853.333333h-170.666666l-25.6-64c-29.866667-12.8-55.466667-25.6-76.8-42.666666l-68.266667 12.8-85.333333-149.333334 42.666666-51.2V512c0-17.066667 0-29.866667 4.266667-42.666667l-42.666667-51.2 85.333334-149.333333 68.266666 12.8c21.333333-17.066667 51.2-34.133333 76.8-42.666667L426.666667 170.666667h170.666666l25.6 64c29.866667 12.8 55.466667 25.6 76.8 42.666666l68.266667-12.8 85.333333 149.333334-42.666666 51.2c4.266667 12.8 4.266667 29.866667 4.266666 42.666666s0 29.866667-4.266666 42.666667l42.666666 51.2-85.333333 149.333333-68.266667-4.266666zM512 554.666667c25.6 0 42.666667-17.066667 42.666667-42.666667s-17.066667-42.666667-42.666667-42.666667-42.666667 17.066667-42.666667 42.666667 17.066667 42.666667 42.666667 42.666667z m0 85.333333c-72.533333 0-128-55.466667-128-128s55.466667-128 128-128 128 55.466667 128 128-55.466667 128-128 128z" fill="#ffffff" p-id="2321"></path></svg><span class="">解析设置</span></a><a href="javascript:;" id="addjiexi" class="elevator-faq" ><svg t="1656638904518" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="7918" width="200" height="200"><path d="M469.333333 469.333333V341.333333h85.333334v128h128v85.333334h-128v128h-85.333334v-128H341.333333v-85.333334h128z m42.666667 384c-187.733333 0-341.333333-153.6-341.333333-341.333333s153.6-341.333333 341.333333-341.333333 341.333333 153.6 341.333333 341.333333-153.6 341.333333-341.333333 341.333333z m0-85.333333c140.8 0 256-115.2 256-256s-115.2-256-256-256-256 115.2-256 256 115.2 256 256 256z" fill="#ffffff" p-id="7919"></path></svg><span class="">添加接口</span></a><a href="javascript:;" id="playing" class="elevator-faq" ><svg t="1651762741797" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="1235" width="200" height="200"><path d="M512 853.333333c-187.733333 0-341.333333-153.6-341.333333-341.333333s153.6-341.333333 341.333333-341.333333 341.333333 153.6 341.333333 341.333333-153.6 341.333333-341.333333 341.333333z m0-85.333333c140.8 0 256-115.2 256-256s-115.2-256-256-256-256 115.2-256 256 115.2 256 256 256z m128-256l-213.333333 128V384l213.333333 128z" fill="#ffffff" p-id="1236"></path></svg><span class="">解析播放</span></a></div>'; document.body.insertAdjacentHTML('afterbegin', btnhtml); commonFunction.removeItem('selectid'); document.querySelector('#playing').onclick = function() { ControllerVideo.autoplay(); commonFunction.Toast('3秒后自动解析视频',3000); }; //弹窗开始------------------------------------------------- document.querySelector('#PlayMain').addEventListener('click',function() { console.log("点击成功"); var ListHtml = ControllerVideo.Videolist(playList); // console.log(ListHtml); var jiexi = commonFunction.getItem('AutoPlay') == 1 ? "checked": ""; commonFunction.tab({ area: ['560', '400'], id: "", btn: ['取消', '保存设置'], btnAlign: 'c', tab: [{ title: '内嵌播放', content: '<div style="margin:10px 30px 0 30px;display:flex"><div style="width:356px;display:inline-block;margin-left: -8px;height: 280px;overflow-y: scroll;" id="jiexilist">' +ListHtml.Insidehtml + '</div><div class="zhihu-scan" ><img src="http://cdn.wezhicms.com/uploads/allimg/20211215/1-21121500044Q94.jpg"><h1>智狐百宝箱</h1><p>微信扫描上方二维码</p><p>关注我</p><p>从此不迷路</p></div></div>' }, { title: '跳转播放', content: '<div style="margin:10px 30px 0 30px;display:flex"><div style="width:356px;display:inline-block;margin-left: -8px;height: 280px;overflow-y: scroll;" id="jiexilist">' + ListHtml.Outsidehtml + '</div><div class="zhihu-scan" ><img src="http://cdn.wezhicms.com/uploads/allimg/20211215/1-21121500044Q94.jpg"><h1>智狐百宝箱</h1><p>微信扫描上方二维码</p><p>关注我</p><p>从此不迷路</p></div></div>' }, { title: '解析设置', content: '<div style="margin:10px 30px 0 30px;display:flex"><div style="width:356px;display:inline-block;padding-right: 15px;height: 280px;overflow-y: scroll;" id="jiexilist"><form class="zhihu-form" ><div class="zhihu-form-item"><label class="zhihu-form-label">自动解析</label><div class="zhihu-input-block"><input type="checkbox" ' + jiexi + ' name="switch" id="autoplay" ></div></div><div class="zhihu-form-item"><label class="zhihu-form-label">解析接口</label><div class="zhihu-input-block"><select name="selectjiexi" lay-verify="required" id ="selectjiexi"><option value="">直接选择或搜索选择</option>' + ListHtml.selecthtml + '</select></div></div></form></div><div class="zhihu-scan" style="width:144px;"><img src="http://cdn.wezhicms.com/uploads/allimg/20211215/1-21121500044Q94.jpg"><h1>智狐百宝箱</h1><p>微信扫描上方二维码</p><p>关注我</p><p>从此不迷路</p></div></div>' }], btn1: function(data) { var s = data.getElementsByTagName('select'); for(let i= 0; i < s.length; i++ ){ let Index = s[i].selectedIndex; let selectedid = s[i].options[Index].value; let selecturl = s[i].options[Index].getAttribute("data-url"); commonFunction.setItem('selectedid', selectedid); commonFunction.setItem('selecturl', selecturl); } var n = data.getElementsByTagName('input'); for(let i= 0; i <n.length; i++ ){ if(n[i].getAttribute("name") == "switch"){ let onswitch = document.querySelector("#autoplay+div").getAttribute("class"); if (onswitch.indexOf("zhihu-form-onswitch") != -1) { commonFunction.setItem('AutoPlay', '1'); ControllerVideo.autoplay(); commonFunction.Toast('3秒后自动解析视频',3000); } else { commonFunction.setItem('AutoPlay', '0'); } } } } }); if (commonFunction.getItem('selectid') != null) { document.querySelector('#' + commonFunction.getItem('selectid')).className += " jiexiselect"; } if (commonFunction.getItem('selectedid') != null) { document.querySelector('#selectjiexi').value = commonFunction.getItem('selectedid'); } var inList = document.getElementsByClassName('inside'); for (var i = 0; i < inList.length; i++) { inList[i].addEventListener('click',function() { if (commonFunction.getItem('selectid') != null) { document.querySelector('#' + commonFunction.getItem('selectid')).classList.remove("jiexiselect"); } commonFunction.Toast('开始解析视频',2000); var playObjecturl = this.getAttribute("data-url"); var playid = this.getAttribute("id"); console.log(playid); commonFunction.setItem('selectid', playid); console.log(commonFunction.getItem('selectid')); this.className = "jiexi inside jiexiselect"; document.body.removeChild(document.querySelector(".zhihu-layer-tab")); document.body.removeChild(document.querySelector(".zhihu-layer-shade")); document.getElementsByTagName("head").item(0).removeChild(document.getElementById("tab")); let url = playObjecturl + window.location.href; console.log(url); ControllerVideo.GoPlay(url); }); } var outList = document.getElementsByClassName('outside'); console.log(outList); for (var u = 0; u < outList.length; u++) { outList[u].addEventListener('click', function() { let playObjecturl = this.getAttribute("data-url"); let Outsideurl = playObjecturl + window.location.href; document.body.removeChild(document.querySelector(".zhihu-layer-tab")); document.body.removeChild(document.querySelector(".zhihu-layer-shade")); document.getElementsByTagName("head").item(0).removeChild(document.getElementById("tab")); console.log(Outsideurl); window.open(Outsideurl); }); } }); //弹窗结束----------------------------------------- document.querySelector('#addjiexi').addEventListener('click',function() { let e = commonFunction.GMgetValue("userplayurl"); console.log(e); if(e == null||e == ""||e == undefined){ let arr =[]; commonFunction.GMsetValue("userplayurl",arr); } let addListHtml = ControllerVideo.Videoaddlist(); let addjiexihtml =""; addjiexihtml +='<form class="zhihu-form" style="height: 325px;margin: 10px 30px 0 30px;"><div style="width:520px;display:inline-block;height:280px;overflow-y: scroll;">' addjiexihtml +='<div class="zhihu-form-item"><textarea placeholder="B站,1,https://jx.m3u8.tv/jiexi/?url= B站,2,https://jx.m3u8.tv/jiexi/?url= 分隔符使用英文逗号,解析名字:B站;1为内部播放,2为跳转播放,解析接口:https://jx.m3u8.tv/jiexi/?url= 如需添加多个解析接口,每行设置一个" class="zhihu-input zhihu-unselect" style="min-height:100px;max-height:160px;max-width:512px;min-width:512px;padding: 10px;"></textarea>' addjiexihtml +='<ul class="addlist"><li><span>解析名称</span><span>播放类型</span><span class="urllist">接口地址</span><span>操作</span></li>'+addListHtml+'</ul></div></div>' addjiexihtml +='</form>' commonFunction.open({ area: ['580', '450'], title: "添加解析接口", shade: 0, id:"", btn: ['取消', '添加接口'], content:addjiexihtml, btn1: function(data) { var s= data.getElementsByTagName('textarea'); for (var i = 0; i < s.length; i++) { let jiexitext = s[i].value; if(jiexitext){ let Alljiexitext = jiexitext.split(/[(\r\n)\r\n]+/); // 根据换行或者回车进行识别 Alljiexitext.forEach((item, index) => { // 删除空项 if (!item) { Alljiexitext.splice(index, 1); } }) Alljiexitext = Array.from(new Set(Alljiexitext)); // 去重 if(Alljiexitext){ Alljiexitext.forEach((item, index) => { if (item) { let jiexiitem = item.split(/,/); let num = index+1 if(jiexiitem.length == 3){ if(jiexiitem[1]==1||jiexiitem[1]==2){ let j = {name:jiexiitem[0],category:jiexiitem[1],url:jiexiitem[2],showType:"1"}; let v= commonFunction.GMgetValue("userplayurl"); let l = v.push(j); commonFunction.GMsetValue("userplayurl",v); commonFunction.Toast("添加成功,请重新设置自动解析接口",1500) console.log(v) }else{ commonFunction.Toast("第"+num+"行格式错误,请按照示例格式重新添加") } }else{ commonFunction.Toast("第"+num+"行格式错误,请按照示例格式重新添加") } } }) } } } } }); var addurlList = document.getElementsByClassName('delurl'); for (var u = 0; u < addurlList.length; u++) { addurlList[u].addEventListener('click', function() { let urlid = this.getAttribute("data-id"); let v= commonFunction.GMgetValue("userplayurl"); v.forEach((item, index) => { if (index == urlid) { v.splice(index, 1); } }); commonFunction.GMsetValue("userplayurl",v); console.log(commonFunction.GMgetValue("userplayurl")); commonFunction.Toast("删除成功,请重新设置自动解析接口",1500) document.body.removeChild(document.querySelector(".zhihu-layer-page")); document.body.removeChild(document.querySelector(".zhihu-layer-shade")); document.getElementsByTagName("head").item(0).removeChild(document.getElementById("open")); document.querySelector('#addjiexi').click(); }); } }); }, //--------------------------------------------------------------------- //手机端 addmobbtn:async function() { await commonFunction.sleep(1000); if(config.host.indexOf("m.le.com")!=-1){ var player = commonFunction.Commonsetinterval("#j-player"); player.then(function(playernode){ playernode.style.display="block"; }); var vipLook = commonFunction.Commonsetinterval("#j-vipLook"); vipLook.then(function(vipLooknode){ vipLooknode.parentNode.removeChild(vipLooknode); }); var daoliu1 = commonFunction.Commonsetinterval(".daoliu1"); daoliu1.then(function(daoliu1node){ daoliu1node.parentNode.removeChild(daoliu1node); }); } var ListHtml = ControllerVideo.Videolist(playList); var offautohtml = '<span id="off">关闭自动解析</span><img src="">' var onautohtml = '<span id="on">开启自动解析</span><img src="">' var autohtml; if (commonFunction.getItem("AutoPlay") == 1) { autohtml = offautohtml } else { autohtml = onautohtml } var mainhtml = '<div class="mob-main"><div class="shaw"></div><div class="listmian"><div class="listmian-tit"><p>解析接口列表</p><div class="title_right" id="autobtn">' + autohtml + '</div></div><div class="list">' + ListHtml.mobhtml + '</div><p class="tips"><span class="ico">*</span><span>开启自动解析后,最后一次选择的接口即自动解析默认接口</span></p><p class="tips"><span class="ico">*</span><span>本脚本仅学习使用,解析接口收集于网络,版权问题联系接口制作者,请勿相信解析接口显示的任何广告</span></p></div></div>' var btnhtml = '<div><div class="elevator"><a class="elevator-msg" id="Showmain"><svg t="1651763850342" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="2320" width="200" height="200"><path d="M661.333333 665.6l51.2 12.8 42.666667-72.533333-34.133333-38.4c4.266667-21.333333 4.266667-38.4 4.266666-55.466667s0-34.133333-4.266666-51.2l34.133333-38.4-42.666667-72.533333-51.2 12.8c-25.6-21.333333-55.466667-42.666667-89.6-51.2L554.666667 256h-85.333334l-17.066666 51.2c-34.133333 8.533333-64 25.6-89.6 51.2l-51.2-12.8-42.666667 72.533333 34.133333 38.4c-4.266667 21.333333-4.266667 38.4-4.266666 55.466667s0 34.133333 4.266666 51.2l-34.133333 38.4 42.666667 72.533333 51.2-12.8c25.6 21.333333 55.466667 42.666667 89.6 51.2L469.333333 768h85.333334l17.066666-51.2c34.133333-8.533333 64-25.6 89.6-51.2z m38.4 81.066667c-21.333333 17.066667-51.2 34.133333-76.8 42.666666L597.333333 853.333333h-170.666666l-25.6-64c-29.866667-12.8-55.466667-25.6-76.8-42.666666l-68.266667 12.8-85.333333-149.333334 42.666666-51.2V512c0-17.066667 0-29.866667 4.266667-42.666667l-42.666667-51.2 85.333334-149.333333 68.266666 12.8c21.333333-17.066667 51.2-34.133333 76.8-42.666667L426.666667 170.666667h170.666666l25.6 64c29.866667 12.8 55.466667 25.6 76.8 42.666666l68.266667-12.8 85.333333 149.333334-42.666666 51.2c4.266667 12.8 4.266667 29.866667 4.266666 42.666666s0 29.866667-4.266666 42.666667l42.666666 51.2-85.333333 149.333333-68.266667-4.266666zM512 554.666667c25.6 0 42.666667-17.066667 42.666667-42.666667s-17.066667-42.666667-42.666667-42.666667-42.666667 17.066667-42.666667 42.666667 17.066667 42.666667 42.666667 42.666667z m0 85.333333c-72.533333 0-128-55.466667-128-128s55.466667-128 128-128 128 55.466667 128 128-55.466667 128-128 128z" fill="#ffffff" p-id="2321"></path></svg><span class="">解析设置</span></a><a id="playing" class="elevator-faq" target="_blank"><svg t="1651762741797" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="1235" width="200" height="200"><path d="M512 853.333333c-187.733333 0-341.333333-153.6-341.333333-341.333333s153.6-341.333333 341.333333-341.333333 341.333333 153.6 341.333333 341.333333-153.6 341.333333-341.333333 341.333333z m0-85.333333c140.8 0 256-115.2 256-256s-115.2-256-256-256-256 115.2-256 256 115.2 256 256 256z m128-256l-213.333333 128V384l213.333333 128z" fill="#ffffff" p-id="1236"></path></svg><span class="">解析播放</span></a></div>' + mainhtml+'</div>'; document.body.insertAdjacentHTML('afterbegin', btnhtml); var css = `body, html { font-family: PingFang SC, HarmonyOS_Regular, Helvetica Neue, Microsoft YaHei, sans-serif; } .elevator { position: fixed; padding: 0 10px; top: 80%; margin-top: -140px; right: 10px; z-index: 899; background: rgb(64 64 64 / 81%); box-shadow: 1px 1px 8px 1px rgb(98 99 99 / 34%); border-radius: 30px; } .elevator a { position: relative; display: block; width: 26px; height: 56px; font-size: 22px; line-height: 20px; color: #b5b9bc; box-sizing: border-box; text-align: center; } .elevator a+a:after { position: absolute; top: 0; left: 50%; margin-left: -12px; content: ''; width: 24px; border: 1px solid #F3F5F7; } .elevator a:hover { color: #14191e; } .elevator .icon { font-size: 24px; line-height: 56px; color: #199b6d; width: 28px; height: 28px; margin: 14px 0; } .elevator .icon:hover { color: #14191e; } .elevator a span { display: none; padding: 14px 0; font-size: 12px; color: #fff; line-height: 14px; } .elevator .elevator-msg:hover .icon, .elevator .elevator-faq:hover .icon, { display: none; } .elevator .elevator-msg:hover span, .elevator .elevator-faq:hover span, { display: inline-block; } .mob-main{ display: none; } .shaw{ width: 100%; height: 100%; position: fixed; top: 0; left: 0; z-index: 99998; background: rgba(0,0,0,0.3); } .listmian{ position: fixed; width:100%; height:400px; bottom: 0; z-index: 99999; border-radius: 14px 14px 0 0; background: #fff; box-shadow: 0 -8px 10px 0 rgba(0,0,0,.09); } .listmian-tit{ background-color: #f5f5f5; height: 60px; position: relative; border-radius: 14px 14px 0 0; } .listmian-tit p { color: #222; font-size: 18px; font-weight: 600; margin-left: 20px; line-height: 60px; float: left; } .listmian-tit .title_right { float: right; margin-right: 20px; line-height: 60px; } .listmian-tit .title_right span{ display: inline-block; color: #222; font-size: 14px; vertical-align: middle; font-weight: 900; } .title_right img{ display: inline-block; width: 12px; height: 12px; margin-left: 3px; vertical-align: middle; } .list{ margin: 10px 20px; display:flex; flex-direction: row; flex-wrap: wrap; justify-content: space-between; height: 240px; overflow-y: scroll; align-content: flex-start } .list span{ display: inline-block; padding: 10px 5px; margin: 0 0 10px 0; background-color: #f6f8fa; border-radius: .07rem; min-width: 90px; text-align: center; font-size: 12px; line-height: 18px; } .jiexiselect{ color: #fc5531; } .tips{ margin: 5px 20px; } .tips span{ font-size: 12px; font-weight: 700; color: #333; line-height: 14px; } .tips .ico{ margin-right: 5px; color: #ff6022; } `; commonFunction.GMaddStyle(css); ControllerVideo.CheckAutoplay(); if (commonFunction.getItem('selectid') != null) { document.querySelector('#' + commonFunction.getItem('selectid')).classList.add("jiexiselect"); } document.querySelector('#playing').addEventListener('click', function() { ControllerVideo.autoplay(); commonFunction.Toast('3秒后自动解析视频',3000); }); document.querySelector('#Showmain').addEventListener('click',function() { document.querySelector(".mob-main").style.display = "block" }); document.querySelector('.shaw').addEventListener('click',function() { document.querySelector(".mob-main").style.display = "none" }) document.querySelector('#autobtn').addEventListener('click',function() { if (commonFunction.getItem('AutoPlay') == 1) { this.innerHTML = onautohtml; commonFunction.setItem('AutoPlay', '0'); } else { this.innerHTML = offautohtml; commonFunction.setItem('AutoPlay', '1'); commonFunction.Toast('请选择自动解析接口',2000); }; }); var list = document.getElementsByClassName('mob-jiexi'); for (var i in list) { list[i].addEventListener('click',function() { commonFunction.Toast('开始解析视频',2000); if (commonFunction.getItem('selectid') != null) { document.querySelector('#' + commonFunction.getItem('selectid')).classList.remove("jiexiselect"); } var playObjecturl = this.getAttribute("data-url"); var playid = this.getAttribute("id"); console.log(playid); commonFunction.setItem('selectid', playid); commonFunction.setItem('selecturl', playObjecturl); this.classList.add("jiexiselect"); document.querySelector(".mob-main").style.display = "none"; let url = playObjecturl + window.location.href; console.log(url); ControllerVideo.GoPlay(url); }) } }, //--------------------------------------------------------------- //检查自动播放 CheckAutoplay:function() { if (commonFunction.getItem("AutoPlay") == 1) { ControllerVideo.autoplay(); commonFunction.Toast('3秒后自动解析视频',3000); } }, //----------------------------------------------------------------------- //自动播放 autoplay:async function(){ await commonFunction.sleep(3000); var f = ""; var autoplayurl; if (commonFunction.getItem('selecturl') != null&&commonFunction.getItem('selecturl') != "null") { f = commonFunction.getItem('selecturl'); } if (f != "") { autoplayurl = f + config.playhref; } else { let defurl = playList[0].url; console.log(defurl); autoplayurl = defurl + config.playhref; } ControllerVideo.GoPlay(autoplayurl); }, //------------------------------------------- //执行播放 GoPlay:function(e){ var playurl = e; var PlayID = ControllerVideo.Playid(); var iframeDivCss = "width:100%;height:100%;" if (config.host.indexOf("m.iqiyi.com") != -1) { iframeDivCss += "position: absolute;top: 0;right: 0;bottom: 0;left: 0;" } var videoPlayer = "<div style='" + iframeDivCss + "' id='zhihuplay'><iframe id='iframe-player-99087lkj' src='" + playurl + "' frameborder='0' allowfullscreen='true' width='100%' height='100%'></iframe></div>"; var b = commonFunction.Videosetinterval(PlayID); b.then(function(Count){ clearInterval(Count); document.querySelector(PlayID).innerHTML = ""; document.querySelector(PlayID).innerHTML = videoPlayer; }); } } //视频解析结束 //优惠券开始 var ControllerCoupon = { CouponidList:function(){ var CouponidList = [ { url:"item.taobao.com", qrname:"淘宝",nodeid:"#J_PromoPrice",goodid:commonFunction.Getgoodid("id"),method:"taobao",action:"getlink"}, { url:"detail.tmall.com", qrname:"天猫",nodeid:"#J_PromoPrice",goodid:commonFunction.Getgoodid("id"),method:"taobao",action:"getlink"}, { url:"detail.tmall.hk", qrname:"天猫",nodeid:"#J_PromoPrice",goodid:commonFunction.Getgoodid("id"),method:"taobao",action:"getlink"}, { url:"chaoshi.detail.tmall.com", qrname:"天猫",nodeid:"#J_PromoPrice",goodid:commonFunction.Getgoodid("id"),method:"taobao",action:"getlink"}, { url:"item.yiyaojd.com", qrname:"京东",nodeid:"#J-summary-top",goodid:commonFunction.geturlid(config.playhref),method:"jd",action:"getdetails"}, { url:"item.jd.com", qrname:"京东",nodeid:"#J-summary-top",goodid:commonFunction.geturlid(config.playhref),method:"jd",action:"getdetails"}, { url:"npcitem.jd.hk", qrname:"京东",nodeid:"#J-summary-top",goodid:commonFunction.geturlid(config.playhref),method:"jd",action:"getdetails"}, { url:"s.taobao.com", qrname:"",nodeid:"pic-link",goodid:"",method:"",action:""}, { url:"list.tmall.com", qrname:"",nodeid:"product",goodid:"",method:"",action:""}, ]; var Couponid = {}; for(var i in CouponidList) { //获得窗口ID if (CouponidList[i].url == config.host) { Couponid = { qrname :CouponidList[i].qrname, nodeid :CouponidList[i].nodeid, goodid :CouponidList[i].goodid, method :CouponidList[i].method, action :CouponidList[i].action, } return Couponid break; } } if(!Couponid){ return; } }, Getcoupon:function() { var Couponid = ControllerCoupon.CouponidList(); console.log(Couponid) if (Couponid.goodid != "") { let headers ={ "Content-Type": "text/html; charset=utf-8" } var request = commonFunction.request("GET","http://tool.zhihupe.com/coupon/getcoupon.php?m=" + Couponid.method + "&act=" + Couponid.action + "&goodid=" + Couponid.goodid,headers); request.then(function(resdata){ if(resdata.result == "success"){ var json = JSON.parse(resdata.data); var code = json.code; if (Couponid.method == "taobao") { if (code == "0") { var longTpwd = json.data.longTpwd var couponUrl = longTpwd.match(/https:\/\/[\d\w\.\/]+/)[0]; console.log(longTpwd); console.log(couponUrl); var couponInfo = json.data.couponInfo; var couponEndTime = json.data.couponEndTime; var actualPrice = json.data.actualPrice; ControllerCoupon.addcoupon(Couponid,couponUrl, couponInfo, couponEndTime, actualPrice) }else{ let u="",f="",t="",p=""; ControllerCoupon.addcoupon(Couponid,u, f, t, p); } } else if (Couponid.method == "jd") { if (code == "0") { var couponConditions = json.data[0].couponConditions; var couponAmount = json.data[0].couponAmount; var jdcouponInfo; if (couponConditions != "") { jdcouponInfo = "满" + couponConditions + "元减" + couponAmount + "元" } else { jdcouponInfo = "无门槛减" + couponAmount + "元" } var jdcouponEndTime = json.data[0].couponEndTime var jdactualPrice = json.data[0].actualPrice; var couponLink = json.data[0].couponLink; ControllerCoupon.addcoupon(Couponid,couponLink, jdcouponInfo, jdcouponEndTime, jdactualPrice) }else{ let u="",f="",t="",p=""; ControllerCoupon.addcoupon(Couponid,u, f, t, p); } } } }); } else { console.log('商品id为空!'); } }, addcoupon:function(Couponid,u, f, t, p) { var imgurl = "http://v.zhihupe.com/enQrcode?url=" + u var mainhtml,qa,cxalink,link; if(Couponid.qrname =="淘宝"){ let ht = document.querySelector("#J_Title"); qa = "淘宝"; link ="http://tool.wezhicms.com/coupon/getscan.php?link="+u cxalink ='http://wxego.yhzu.cn/?r=/l&kw='+encodeURI(ht.querySelector("h3").innerText)+'&sort=0'; }else if(Couponid.qrname =="天猫"){ let hm = document.querySelector(".tb-detail-hd"); cxalink ='http://wxego.yhzu.cn/?r=/l&kw='+encodeURI(hm.querySelector("h1").innerText)+'&sort=0'; link ="http://tool.wezhicms.com/coupon/getscan.php?link="+u qa = "淘宝"; }else if(Couponid.qrname =="京东"){ cxalink = 'http://wxego.yhzu.cn/?r=/l/jdlist&kw='+encodeURI(document.querySelector(".sku-name").innerText)+'&sort=0'; link = u qa = "京东"; } if (f != "" && u != "") { mainhtml = '<div style="text-align: center;font-size: 14px;width: 25%;"><img style="width: 100%;height: auto;"src="' + imgurl + '"><p style="font-size: 12px;margin-top: 5px;">手机' + qa + '扫码领取</p></div><div style="width: 72%;"><p style="margin-bottom:10px;font-size: 18px;font-weight: 700;">优惠劵:' + f + '</p><p style="margin-bottom:10px;font-size: 14px;color:#999;">有效期至:' + t + '</p><div style="display: flex;justify-content: space-between;align-items: flex-start;"><div><span style="font-size:14px">劵后价:</span><span style="font-size: 18px;font-weight: 700;color: #F40;">¥</span><span style="font-size: 26px;font-weight: 700;font-family: PingFang SC, HarmonyOS_Regular, Helvetica Neue, Microsoft YaHei, sans-serif;color: #F40;">' + p + '</span></div><a href="' + link + '"><span style="padding: 10px 20px;background-color: #df3033;font-size: 18px;color: #fff;font-weight: 700;">领券购买</span></a></div></div>' } else { mainhtml = '<div style="font-size: 18px;font-weight: 700;">暂无优惠券</div><a id="cxalink" style="background: #df3033;padding: 10px;color: #fff;font-size: 12px;">查询同款商品优惠</a>' } var couponhtml = '<div id="videocoupon" style="margin-top: 10px;background: #f1f1f100;padding: 15px 25px;display:flex;align-items: center;justify-content: space-between;margin-bottom:5px;font-family: PingFang SC, HarmonyOS_Regular, Helvetica Neue, Microsoft YaHei, sans-serif;">' + mainhtml + '</div>'; var Couponnodeid= commonFunction.Commonsetinterval(Couponid.nodeid); Couponnodeid.then(function(node){ let b = document.createElement('div'); b.innerHTML = couponhtml; let n = document.querySelector("#wenkucoupon"); if(!n){ node.parentNode.appendChild(b) document.querySelector("#cxalink").addEventListener('click',function() { window.open(cxalink); }) } }); }, //淘宝搜索页 taobaoso:function(){ var Couponid = ControllerCoupon.CouponidList(); var Coupontbso= commonFunction.Commonsetinterval("."+Couponid.nodeid); Coupontbso.then(function(node){ let a = document.getElementsByClassName(Couponid.nodeid); for (var i = 0; i < a.length; i++) { let nid =a[i].getAttribute("data-nid"); let headers ={ "Content-type": "application/json" } var request = commonFunction.request("GET","http://v2.api.haodanku.com/item_detail?apikey="+config.hdapikey+"&itemid="+nid,headers); request.then(function(resdata){ if(resdata.result == "success"){ let obj = JSON.parse(resdata.data); console.log(obj); if(obj.code ==1&&obj.data.couponmoney!=0){ let b = document.createElement('div'); b.style="position: absolute;top: 10px;right: 5px;font-size: 14px;font: 12px/1.5 PingFangSC-Regular,Helvetica,Arial,'Microsoft Yahei',sans-serif;z-index: 99999;"; b.innerHTML = '<span style="background: #F40;padding: 4px;color: #fff;border: 1px solid red;border-radius: 3px 0 0 3px;font-weight: bold;">券</span><span style="border: 1px solid #ff00001f;border-radius: 0 3px 3px 0;padding: 4px;color: #F40;background: #fff;">优惠'+obj.data.couponmoney+'元</span>'; document.querySelector("#J_Itemlist_PLink_"+nid).appendChild(b) } } }); } }); }, //天猫搜索页 tmallso:function(){ var Couponid = ControllerCoupon.CouponidList(); var Coupontmso= commonFunction.Commonsetinterval("."+Couponid.nodeid); Coupontmso.then(function(node){ let a = document.getElementsByClassName(Couponid.nodeid); ControllerCoupon.tmalllist(-1,a); }); }, tmalllist:function(i,a){ setTimeout(function(){ if(++i < a.length){ let nid =a[i].getAttribute("data-id"); var m = document.getElementsByClassName("product")[i]; let headers ={ "Content-type": "application/json" } var request = commonFunction.request("GET","http://v2.api.haodanku.com/item_detail?apikey="+config.hdapikey+"&itemid="+nid,headers); request.then(function(resdata){ if(resdata.result == "success"){ let obj = JSON.parse(resdata.data); if(obj.code ==1&&obj.data.couponmoney!=0){ let b = document.createElement('div'); b.style="position: absolute;top: 10px;right: 5px;font-size: 14px;font: 12px/1.5 PingFangSC-Regular,Helvetica,Arial,'Microsoft Yahei',sans-serif;z-index: 99999;"; b.innerHTML = '<span style="background: #F40;padding: 4px;color: #fff;border: 1px solid red;border-radius: 3px 0 0 3px;font-weight: bold;">券</span><span style="border: 1px solid #ff00001f;border-radius: 0 3px 3px 0;padding: 4px;color: #F40;background: #fff;">优惠'+obj.data.couponmoney+'元</span>'; console.log(obj.data.couponmoney); m.appendChild(b); } ControllerCoupon.tmalllist(i,a); } }); } }, Math.random() * 10); }, } //优惠券结束 //历史价格查询开始 var ControllerHistory ={ History:function(){ var Couponid = ControllerCoupon.CouponidList(); var gid = Couponid.goodid; let HistoryHtml ='<div style="font-family: PingFang SC, HarmonyOS_Regular, Helvetica Neue, Microsoft YaHei, sans-serif!important;"><div style="font-size: 18px;font-weight: bold;margin: 0px;text-align: center;">商品历史价格对比查询</div><div id="history"><div><div id="historyhead" style="font-size: 14px;text-align: center;margin-top: 10px;"></div></div><div style="height:400px;" id="container"><span style="text-align: center;font-size: 24px;font-weight: bold;margin: 0 auto;display: block;line-height: 400px;">数据查询中,请稍后...</span></div></div>' var goodurl,Historynode; if(Couponid.method == "taobao"){ if(config.host.indexOf("taobao")!=-1){ goodurl ="https://detail.tmall.com/item.htm?id=" + gid; }else{ goodurl ="https://"+config.host+"/item.htm?id=" + gid; } Historynode = "#detail"; }else if(Couponid.method == "jd"){ goodurl ="https://item.jd.com/"+ gid+".html"; Historynode = ".product-intro" } var addHistory= commonFunction.Commonsetinterval(Historynode); addHistory.then(function(node){ let b = document.createElement('div'); b.style = "padding:20px;border: 1px solid #eee;margin: 10px auto;position: relative;clear: both;" b.innerHTML = HistoryHtml; node.appendChild(b); ControllerHistory.getHistory(goodurl); }); }, getHistory:function(goodurl){ let headers ={ 'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/96.0.4664.110 Safari/537.36', 'Accept-Language': 'zh-CN,zh;q=0.9', 'Content-Type': 'text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9', 'sec-ch-ua-platform': 'Windows', 'Sec-Fetch-Mode': 'cors', 'Sec-Fetch-Dest': 'empty', 'Sec-Fetch-Site': 'same-origin', 'Accept-Encoding': 'gzip, deflate, br', 'Sec-Fetch-User': '?1', 'Connection': 'keep-alive', 'Host': 'bijiatool-v2.manmanbuy.com', } var request = commonFunction.request("POST","https://bijiatool-v2.manmanbuy.com/ChromeWidgetServices/WidgetServices.ashx?methodName=getBiJiaInfo&jsoncallback=&p_url=" + goodurl,headers); request.then(function(resdata){ if(resdata.result == "success"){ let obj = JSON.parse(resdata.data); if(obj.jiagequshi ==undefined||obj.jiagequshiyh ==""){ document.querySelector("#history").innerHTML='<div style="text-align: center;margin: 20px 0;font-size: 14px;">暂未收录</div>'; }else{ let headhtml ='<div> 历史最低价格 <span style="margin-right: 20px;">'+obj.lowerPriceyh+'元</span><span style="margin-right: 20px;">数据来源于网络,仅供参考</span> </div>' document.querySelector("#historyhead").innerHTML =headhtml; ControllerHistory.Showchart(obj); } } }); }, Showchart:function(obj){ var strDate = obj.jiagequshiyh; var chartDom = document.getElementById('container'); var myChart = echarts.init(chartDom); var option; var oldData = []; var data = []; var currentDay = new Date().setHours(0, 0, 0, 0); var currentDayDate = new Date(currentDay).getTime(); var minMonth =4,xBlockNum=6; oldData = eval("([" + strDate + "])"); for (var i = 1; i < oldData.length; i++) { var key = oldData[i][0]; var j = i - 1; while (j >= 0 && oldData[j][0] > key) { oldData[j + 1] = oldData[j]; j--; } oldData[j + 1][0] = key; } var xInterval, yInterval, yMin, yMax, xMin, xMax, maxValue, minValue, maxDate, minDate, addDate; addDate = minMonth * 30 * 24 * 60 * 60 * 1000; //日期不足三个月,补到120天 var arrX = [], arrY = []; console.log(oldData); for (var l = 0; l < oldData.length;l++) { if (oldData[l][1] <= 0) continue; arrX.push(oldData[l][0]); arrY.push(oldData[l][1]); data.push([oldData[l][0], oldData[l][1],oldData[l][2]]); } console.log(oldData); if (data.length > 0 && data[data.length - 1][0] < currentDayDate) { data.push([currentDayDate, data[data.length - 1][1], ""]); } maxValue = Math.max.apply(null, arrY); //y轴最大值 minValue = Math.min.apply(null, arrY); //y轴最小值 maxDate = new Date(data[data.length - 1][0]).getTime(); //最大日期 minDate = new Date(data[0][0]).getTime(); //最小日期 yMin = minValue - ((minValue + maxValue) / 2 - minValue); //y轴开始最小值 yMin = yMin >= 0 ? yMin : 0; yMax = maxValue + (maxValue - minValue) / 4; if (yMax === yMin) { yMin = yMin - yMin / 2; yMax = yMax + yMax / 2; } if (maxDate - minDate > addDate) { xMin = minDate; } else { xMin = maxDate - addDate; //往前补四个月 } xMax = maxDate; xInterval = (xMax - xMin) / xBlockNum; yInterval = (yMax - yMin) / xBlockNum; console.log(arrX ); option = { animation: false, tooltip: { trigger: 'axis', transitionDuration: 0, confine: true, backgroundColor: 'transparent', padding: 0, borderWidth: 0, borderColor: '#ec652e', position: function (point, params, dom) { var width = dom.clientWidth; return [point[0] - width / 2, 0]; }, formatter: function (obj) { if (obj.length > 0) { var timeArr = ControllerHistory.getLocalTime(obj[0].data[0]).split('-'); var time = timeArr[0] + '年' + timeArr[1] + '月' + timeArr[2] + '日'; var minPrice = obj[0].data[1]; var youhui = obj[0].data[2]; for (var i = 1; i < obj.length; i++) { if (obj[i].data[1] < minPrice) { minPrice = obj[i].data[1]; youhui = obj[i].data[1]; } } var retHTML = '<div style="border-radius:10px;padding:0 10px;height:22px;line-height:22px;background:#ec652e; color:#ffffff; font-size:11px;">' + time + ' ¥' + minPrice + '</div>'; if (youhui.length > 0) { retHTML = '<div style="border-radius:10px;padding:0 10px;height:44px;line-height:22px;background:#ec652e; color:#ffffff; font-size:11px;">' + time + ' ¥' + minPrice + "<br/>" + youhui + '</div>'; } var curDate = new Date(); var vDate = new Date(obj[0].data[0]); if (obj[0].dataIndex === 0 && vDate > new Date(curDate.getTime() - 24 * 60 * 60 * 1000 * 25 * 30)) { if (youhui.length > 0) { retHTML = '<div style="border-radius:10px;padding:0 10px;height:22px;line-height:44px;background:#ec652e; color:#ffffff; font-size:11px;">第一次收录 ' + time + ' ¥' + minPrice + "<br/>" + youhui + '</div>'; } else { retHTML = '<div style="border-radius:10px;padding:0 10px;height:22px;line-height:22px;background:#ec652e; color:#ffffff; font-size:11px;">第一次收录 ' + time + ' ¥' + minPrice + '</div>'; } } return retHTML; } }, axisPointer: { type: 'line', lineStyle: { color: '#ec652e' } } }, grid: { left: "3%", right: "3%", bottom: "3%", top: 20, containLabel: true }, xAxis: { type: 'time', axisTick: { show: false }, axisLine: { lineStyle: { color: '#dddddd' } }, interval: xInterval, boundaryGap: false, align: 'right', axisLabel: { align: 'right', rotate: 0, color: '#555555', showMinLabel: true, showMaxLabel: true, formatter: function (value, index) { var date = new Date(value); //var texts = [(date.getMonth() + 1) > 9 ? (date.getMonth() + 1) : ('0' + (date.getMonth() + 1)), date.getDate() > 9 ? date.getDate() : ('0' + date.getDate())]; var texts = [(date.getMonth() + 1), date.getDate()]; if (index === 0) { texts = ['']; } else if (index === (arrX.length - 1)) { //texts.unshift(date.getFullYear()); } else { //texts = ['']; } return texts.join('-'); } }, splitLine: { show: true, lineStyle: { color: ['#ddd'], type: 'solid', opacity: .8 } }, min: function (value) { return xMin; }, max: function (value) { return xMax; } }, yAxis: { type: 'value', axisTick: { show: false }, interval: yInterval, boundaryGap: false, scale: true, axisLabel: { show: true, inside: false, showMinLabel: true, showMaxLabel: true, color: '#555', formatter: function (value, index) { if (index === 0) { } else { return value.toFixed(0); } } }, axisLine: { lineStyle: { color: '#dddddd' } }, splitLine: { show: true, lineStyle: { color: ['#ddd'], type: 'solid', opacity: .8 } }, //最小刻度 min: function (value) { return yMin; }, max: function (value) { return yMax; } }, series: [{ name: '价格', type: 'line', symbol: 'circle', symbolSize: [2, 2], showSymbol: false, itemStyle: { color: '#ff6729' }, lineStyle: { width: 2, shadowColor: '#dddddd', shadowBlur: 0, shadowOffsetY: 0.3, shadowOffsetX: 0, z: 22 }, markLine: { silent: true, symbol: 'none', data: [{ type: 'max', symbol: 'none', lineStyle: { color: '#888888', type: 'dotted', width: 0.8 }, label: { position: 'end', formatter: '{c}', color: 'transparent' //color: '#555555' } }, { type: 'min', symbol: 'none', lineStyle: { color: '#888888', type: 'dotted', width: 0.8 }, label: { position: 'end', formatter: '{c}', color: '#555555' } }], label: { show: true, position: 'left' } }, data: data }], }; if (maxDate - minDate < addDate) { var lineDash = [{ coord: [xMin, arrY[0]], lineStyle: { width: 1.3 } }, { coord: [arrX[0], arrY[0]] }]; option.series[0].markLine.data.push(lineDash) } myChart.clear(); myChart.setOption(option, true); myChart.dispatchAction({ type: 'showTip', seriesIndex: 1, dataIndex: 1 }) }, getLocalTime:function(nS) { var year = new Date(parseInt(nS)).getFullYear(); var mouth = new Date(parseInt(nS)).getMonth() + 1; mouth = mouth < 10 ? '' + mouth : mouth; var day = new Date(parseInt(nS)).getDate() < 10 ? '' + new Date(parseInt(nS)).getDate() : new Date(parseInt(nS)).getDate(); return year + '-' + mouth + '-' + day; }, } //历史价格查询结束 //短视频下载开始 var ControllerShortvideo ={ ShortvideoidList:function(){ var ShortvideoidList = [ { url:"www.douyin.com", videoid:commonFunction.geturlid(config.playhref),nodeid:".xg-right-grid"}, { url:"www.kuaishou.com", videoid:commonFunction.geturlid(config.playhref),nodeid:".right"}, { url:"www.ixigua.com", videoid:commonFunction.geturlid(config.playhref),nodeid:".xg-right-grid"}, ]; var Shortvideoid = {}; for(var i in ShortvideoidList) { //获得窗口ID if (ShortvideoidList[i].url == config.host) { Shortvideoid = { videoid :ShortvideoidList[i].videoid, nodeid :ShortvideoidList[i].nodeid } return Shortvideoid break; } } if(!Shortvideoid){ return; } }, ToastDwon:function(videourl,filename,mode) { var m = document.createElement('div'); m.innerHTML ='<h3 style="text-align: center;margin: 15px 0;font-size: 18px;font-weight: bold;"> 下载视频 </h3><div style="word-break: break-all;padding: 10px;background: #f1f1f1; font-size: 12px; height: 100px;overflow-y: scroll;box-sizing: border-box;margin-bottom: 10px;border-radius: 5px;"><p>'+videourl+'</p> </div><div style="display: flex;float: right;font-size: 14px;"><div id="close" style="margin-right: 15px;">关闭</div> <div> <a id="videofile">下载</a></div></div><div style="float: left;font-size: 14px;"><div> <a href="'+videourl+'" target="_blank">浏览器打开</a></div></div>'; m.setAttribute('id','dwon'); m.style.cssText = "max-width: 480px;min-width: 150px;padding: 0 25px;height: 200px;color: #323442;line-height: 20px;border-radius: 4px;position: fixed;top: 50%;left: 50%;transform: translate(-50%, -50%);z-index: 999998;background: #fff;font-size: 16px;box-shadow: 1px 1px 50px rgb(0 0 0 / 40%);font-family: PingFang SC, HarmonyOS_Regular, Helvetica Neue, Microsoft YaHei, sans-serif;"; document.body.appendChild(m); document.querySelector("#close").addEventListener('click',function() { document.body.removeChild(document.querySelector("#dwon")) }) document.querySelector("#videofile").addEventListener('click',function() { commonFunction.Toast("创建下载需要时间,长时间未创建,点击浏览器打开,右键另存为",4000); if(mode ==1){ GM_download({ url:videourl+'.mp4', name: filename, saveAs: true, //布尔值,显示"保存为"对话框 onerror: function (error) { commonFunction.Toast("下载出错,点击浏览器打开手动保存",3000) }, onprogress: (pro) => { }, ontimeout: () => { //如果此下载由于超时而失败,则要执行的回调 commonFunction.Toast("下载超时,点击浏览器打开手动保存",3000) }, onload: () => { commonFunction.Toast(filename+"下载完成",3000) } }) }else{ fetch(videourl+'.mp4').then(res => res.blob()).then(blob => { const a = document.createElement('a'); document.body.appendChild(a) a.style.display = 'none' const url = window.URL.createObjectURL(blob); a.href = url; a.download = filename; a.click(); document.body.removeChild(a) window.URL.revokeObjectURL(url); }); } }) },//公共下载弹窗结束 //抖音下载开始 douyinbtn:function() { var Shortvideoid = ControllerShortvideo.ShortvideoidList(); let downhtml = '<div class="xgplayer-icon"><div class="xgplayer-setting-label"><span class="xgplayer-setting-title">下载</span></div></div>'; var douyin= commonFunction.Commonsetinterval(Shortvideoid.nodeid); douyin.then(function(node){ var b = document.createElement('xg-icon'); b.innerHTML = downhtml; b.setAttribute("class","xgplayer-autoplay-setting automatic-continuous"); b.setAttribute("id","downvideo"); node.appendChild(b); ControllerShortvideo.getdouyinvideo(Shortvideoid.videoid); }); }, getdouyinvideo:function(d){ document.querySelector('#downvideo').addEventListener('click',function() { commonFunction.Toast("正在获取视频文件",3000) if (d != "") { var request = commonFunction.request("GET","https://www.iesdouyin.com/web/api/v2/aweme/iteminfo/?item_ids=" + d,null,null); request.then(function(resdata){ if(resdata.result == "success"){ var json=JSON.parse(resdata.data); console.log(json) if(json.status_code==0){ let vid = json.item_list[0].video.vid; if(vid){ var filename = d+".mp4"; var url = "https://aweme.snssdk.com/aweme/v1/play/?video_id="+vid+"&ratio=1080p&line=0"; commonFunction.Toast("视频获取成功",3000) ControllerShortvideo.ToastDwon(url,filename,1); }else{ commonFunction.Toast("视频文件获取失败",3000) } } } }); } else { console.log('视频id为空!'); } }); },//抖音下载结束 //快手下载开始 kuaishoubtn:function() { var Shortvideoid = ControllerShortvideo.ShortvideoidList(); var kuaishou= commonFunction.Commonsetinterval(Shortvideoid.nodeid); kuaishou.then(function(node){ var b = document.createElement('div'); b.innerHTML = '<div>下载</div>'; b.setAttribute("class","kwai-player-volume-container player-bar-volume show-volume-slide"); b.setAttribute("data-v-0c78ed39",""); b.setAttribute("data-v-5037d859",""); b.setAttribute("data-v-2475c26c",""); b.setAttribute("data-v-56544f8e",""); b.setAttribute("id","downvideo"); node.insertBefore(b,node.childNodes[0]); if(config.playhref.indexOf("short-video")!=-1){ var e = document.querySelector(".total") e.style.right ="180px" var f = document.querySelector(".player-bar-progress") f.style.width ="calc(100% - 318px)"; } ControllerShortvideo.getksvideo(Shortvideoid.videoid) }); }, getksvideo:function(d){ document.querySelector('#downvideo').addEventListener('click',function() { commonFunction.Toast("正在获取视频文件",1000) let videonode = document.querySelector("video") let src =videonode.getAttribute("src") let pausebtn = document.querySelector(".pause-icon"); if(pausebtn != null){ pausebtn.click(); } if(src.indexOf("blob:") != -1){ let params ='{"operationName":"visionVideoDetail","variables":{"photoId":"'+d+'","page":"detail"},"query":"query visionVideoDetail($photoId: String, $type: String, $page: String, $webPageArea: String) {\\n visionVideoDetail(photoId: $photoId, type: $type, page: $page, webPageArea: $webPageArea) {\\n status\\n type\\n author {\\n id\\n name\\n following\\n headerUrl\\n __typename\\n }\\n photo {\\n id\\n duration\\n caption\\n likeCount\\n realLikeCount\\n coverUrl\\n photoUrl\\n liked\\n timestamp\\n expTag\\n llsid\\n viewCount\\n videoRatio\\n stereoType\\n croppedPhotoUrl\\n manifest {\\n mediaType\\n businessType\\n version\\n adaptationSet {\\n id\\n duration\\n representation {\\n id\\n defaultSelect\\n backupUrl\\n codecs\\n url\\n height\\n width\\n avgBitrate\\n maxBitrate\\n m3u8Slice\\n qualityType\\n qualityLabel\\n frameRate\\n featureP2sp\\n hidden\\n disableAdaptive\\n __typename\\n }\\n __typename\\n }\\n __typename\\n }\\n __typename\\n }\\n tags {\\n type\\n name\\n __typename\\n }\\n commentLimit {\\n canAddComment\\n __typename\\n }\\n llsid\\n danmakuSwitch\\n __typename\\n }\\n}\\n"}'; let headers = { "Content-type": "application/json" }; var request = commonFunction.request("POST","https://www.kuaishou.com/graphql",headers,params); request.then(function(resdata){ if(resdata.result == "success"){ let obj=JSON.parse(resdata.data); let src=obj.data.visionVideoDetail.photo.photoUrl; commonFunction.Toast("视频获取成功",1000) ControllerShortvideo.ToastDwon(src,d,"") } }) }else{ commonFunction.Toast("视频获取成功",1000) ControllerShortvideo.ToastDwon(src,d,"") } }) }, //快手下载结束 //西瓜视频下载开始 xiguabtn:function() { var Shortvideoid = ControllerShortvideo.ShortvideoidList(); var xigua= commonFunction.Commonsetinterval(Shortvideoid.nodeid); xigua.then(function(node){ let btnHTML = '<div id="downvideo" class="playerControlsItemContainer" ><div class="xgplayer-control-item control_definition common-control-item"><div class="xgplayer-control-item__entry"><div class="xgpcPlayer_textEntry"><span>下载</span></div></div></div></div>'; node.insertAdjacentHTML('afterbegin', btnHTML); ControllerShortvideo.getxgvideo(Shortvideoid.videoid) }); }, getxgvideo:function(d){ document.querySelector('#downvideo').addEventListener('click',function() { commonFunction.Toast("正在获取视频文件",1000); let headers = { "Content-type": "application/json" }; let request = commonFunction.request("POST","http://47.99.158.118/video-crack/v2/parse?content="+config.playhref,headers,null); request.then(function(resdata){ if(resdata.result == "success"){ let obj=JSON.parse(resdata.data); if(obj.code == 0){ commonFunction.Toast("视频获取成功",1000) ControllerShortvideo.ToastDwon(obj.data.url,d) }else { commonFunction.Toast("此视频不支持解析") } } }) }) } //西瓜视频下载结束 } //短视频下载结束 //aria2设置开始 var Controlleraria2 = { aria2set:function(b){ let css= ` .layui-form{ display: flex; margin-top: 20px; } .layui-form-label { box-sizing: content-box; } .layui-input-block p{ font-size:12px } .layui-form-item{ margin-bottom:5px } .layui-input-block{ min-height:auto; } .main-left{ width: 367px; } .zhihu-scan{ width:180px; display:inline-block; text-align: center; margin-right: 40px; } .zhihu-scan img{ width: 140px; margin: 0 5px 10px 5px; } .zhihu-scan h1{ font-size: 18px; font-weight: bold; margin: 0px 0 20px 0; } .zhihu-scan p{ margin: 0; color: #666; font-size: 14px; } `; commonFunction.GMaddStyle(css); document.querySelector("#aria2set") .addEventListener('click',function() { let rpc="ws://localhost:6800/jsonrpc"; if(commonFunction.getItem("rpc")!=null){ rpc= commonFunction.getItem("rpc") } let token=""; if(commonFunction.getItem("token")!=null){ token= commonFunction.getItem("token") } let mulu="D:/"; if(commonFunction.getItem("mulu")!=null&&commonFunction.getItem("mulu")!=""){ mulu= commonFunction.getItem("mulu") } let plcode=""; if(commonFunction.getItem("plcode")!=null){ plcode= commonFunction.getItem("plcode") } let contenthtml =""; contenthtml +='<form class="zhihu-form" style="height: 325px;"><div class="main-left">' contenthtml +='<div class="zhihu-form-item"> <label class="zhihu-form-label">RPC地址</label><div class="zhihu-input-inline"><input name="rpc" value="'+rpc+'" placeholder="" class="zhihu-input"></div></div>' contenthtml +='<div class="zhihu-form-item" style="color: #acaeb5;"><div class="zhihu-input-block"><p>Aria2配置:ws://localhost:6800/jsonrpc<br>Motrix配置:ws://localhost:16800/jsonrpc</p></div></div>' contenthtml +='<div class="zhihu-form-item"> <label class="zhihu-form-label">token</label><div class="zhihu-input-inline"><input name="token" value="'+token+'" placeholder="" class="zhihu-input"></div></div>' contenthtml +='<div class="zhihu-form-item" style="color: #acaeb5;"><div class="zhihu-input-block"><p>没有请留空</p></div></div>' contenthtml +='<div class="zhihu-form-item"> <label class="zhihu-form-label">保存地址</label><div class="zhihu-input-inline"><input name="mulu" value="'+mulu+'" placeholder="留空使用默认目录" class="zhihu-input"></div></div>' contenthtml +='<div class="zhihu-form-item" style="color: #acaeb5;"><div class="zhihu-input-block"><p>留空使用默认目录</p></div></div>' contenthtml +='<div class="zhihu-form-item"> <label class="zhihu-form-label">验证码</label><div class="zhihu-input-inline"><input name="plcode" value="'+plcode+'" placeholder="请输入验证码" class="zhihu-input"></div></div>' contenthtml +='<div class="zhihu-form-item" style="color: #acaeb5;"><div class="zhihu-input-block"><p>批量下载需要关注公众号</p></div></div>' contenthtml +='</div><div class="zhihu-scan"><img src="http://cdn.wezhicms.com/uploads/allimg/20211215/1-21121500044Q94.jpg"><h1>验证码获取</h1>' contenthtml +='<div style="font-size: 12px;color: #000;margin-left:15px;text-align: left;"><div style="line-height: 3;">1.关注公众号【智狐百宝箱】</div><div style="line-height: 2;">2.回复大写字母‘B’获取验证码</div><div style="line-height: 3;">3.将验证码输入左边输入框中</div></div></div></form>' commonFunction.open({ area: ['580', '450'], title: "批量下载设置", shade: 0, id:"biliset", btn: ['取消', '保存设置'], content:contenthtml, btn1: function(data) { var n = data.getElementsByTagName('input'); for(let i= 0; i <n.length; i++ ){ if (n[i].getAttribute("name") == "rpc") { commonFunction.setItem("rpc",n[i].value); } else if (n[i].getAttribute("name") == "token") { commonFunction.setItem("token",n[i].value); } else if (n[i].getAttribute("name") == "mulu") { commonFunction.setItem("mulu",n[i].value); } else if (n[i].getAttribute("name") == "plcode") { if(n[i].value != ""){ commonFunction.setItem("plcode",n[i].value); }else{ commonFunction.setItem("plcode",""); commonFunction.Toast('请在脚本设置里输入验证码!'); } } } } }); }); document.querySelector("#all") .addEventListener('click',function() { b.forEach(function(element) { element.checked = true; }) commonFunction.Toast("已经全部选择",3000) }); document.querySelector("#delall") .addEventListener('click',function() { b.forEach(function(element) { element.checked = false; }); commonFunction.Toast("已经全部取消选择",3000) }); }, addUri:function(u,t) { //配置 return new Promise(function(resolve, reject) { var wsurl = commonFunction.getItem("rpc");; var uris = [u]; var token=""; var filename = t if(commonFunction.getItem("mulu")!=null&&commonFunction.getItem("mulu")!=""){ var mulu= commonFunction.getItem("mulu") }else{ mulu ="D:/" } var options = { "dir":mulu, "max-connection-per-server": "16", "header": [ "User-Agent: "+config.UA, "Referer: "+config.playhref ] }; if (filename != "") { options.out = filename; } var json = { "id": "zhihu", "jsonrpc": '2.0', "method": 'aria2.addUri', "params": [uris, options], }; console.log(json) if (token != "") { json.params.unshift("token:" + token); // 坑死了,必须要加在第一个 } var ws = new WebSocket(wsurl); ws.onerror = event => { console.log(event); commonFunction.Toast('连接错误, Aria2 连接错误,请检查RPC设置!'); }; ws.onopen = () => { ws.send(JSON.stringify(json)); } ws.onmessage = event => { let received_msg = JSON.parse(event.data); console.log(received_msg); if (received_msg.error !== undefined) { if (received_msg.error.code === 1)commonFunction.Toast('通过RPC连接失败', '请打开控制台查看详细错误信息,返回信息:' + received_msg.error.message); } resolve(); switch (received_msg.method) { case "aria2.onDownloadStart": commonFunction.Toast("Aria2 发送成功, "+filename+" 已经开始下载!",1000); ws.close(); break; default: break; } }; }); }, plaria2:function(i,arr){ setTimeout(function(){ if(++i < arr.length){ Controlleraria2.addUri(arr[i].url,arr[i].title) Controlleraria2.plaria2(i,arr); console.log(i,arr.length) } }, Math.random() * 1000); } }; //aria2设置结束 //Bilibili下载开始 var ControllerBilibili ={ Getaid:function(Bv){ var headers = { "Content-type": "application/json" }; let request = commonFunction.request("GET","http://api.bilibili.com/x/web-interface/archive/stat?bvid="+Bv,headers,null); request.then(function(resdata){ if(resdata.result == "success"){ let obj=JSON.parse(resdata.data); if(obj.code ==0){ let aid = obj.data.aid; console.log(aid) let request2 = commonFunction.request("GET","https://api.bilibili.com/x/web-interface/view?aid="+aid,headers,null); request2.then(function(resdata2){ let obj=JSON.parse(resdata2.data); if(obj.code == 0){ let arr = obj.data.pages; console.log(arr); var Bilihtml="" for (var i = 0; i < arr.length; i++) { Bilihtml += '<li><a href="javascript:void(0)" class="router-link-active" ><div class="clickitem"><div class="link-content"><input data-aid="'+aid+'" data-cid="'+arr[i].cid+'" title="'+arr[i].part+'" type="checkbox" style="margin-right:5px"> <span class="page-num">P'+arr[i].page+'</span><span class="part">'+arr[i].part+'</span></div><div class="duration bilidown" data-aid="'+aid+'" data-cid="'+arr[i].cid+'" title="'+arr[i].part+'">下载</div></div></a></li>'; } ControllerBilibili.addbililist(Bilihtml); }else{ commonFunction.Toast("获取下载列表失败"); } }) } } }) },//获取aid结束 //增加下载列表开始 addbililist:async function(html) { await commonFunction.sleep(3000); var AddBi= commonFunction.Commonsetinterval("#danmukuBox"); AddBi.then(function(node){ let dataV = node.attributes[2].name; let downhtml = '<div id ="downBox" class="multi-page report-wrap-module report-scroll-module" '+dataV+' style="margin:0 0 10px 0;border-radius: 6px;background: #F1F2F3;"><div class="head-con"><div class="head-left"><h3>下载列表</h3></div><div class="head-right"><span class="next-button" id="sanlian"><span class="txt" style="color: #00a1d6;">一键三连</span></span></div></div><div class="cur-list"><ul class="list-box">'+html+'</ul></div><div style="display: flex;justify-content: space-between;height: 42px;line-height: 42px;margin: 0px 15px;font-size: 14px;font-weight: bold;border-top: 1px solid #dadada;"><div><span style="margin-right: 20px;" id="all">全选</span><span id="delall">重置</span></div><div><span style="margin-right: 20px;" id="aria2set">设置</span><a id="pldown"><span>批量下载</span></a></div></div></div>'; node.insertAdjacentHTML('afterEnd', downhtml); ControllerBilibili.bilibilidown(); }); }, bilibilidown:function(){ var inu = document.querySelector("#downBox"); var b=inu.getElementsByTagName('input'); Controlleraria2.aria2set(b); document.querySelector("#sanlian") .addEventListener('click',function() { console.log("一键三连"); document.querySelector(".like").click(); document.querySelector(".coin").click(); }); document.querySelector("#pldown") .addEventListener('click',function() { let passwordCode = commonFunction.getItem("plcode"); if (passwordCode !=""&&passwordCode !=null) { let headers = { "Content-Type": "text/html; charset=utf-8" }; let request = commonFunction.request("GET","http://tool.zhihupe.com/bdwpcs.php?m=BILIBILI&author="+author+"&PWD="+passwordCode,headers,null); request.then(function(resdata){ let json=JSON.parse(resdata.data); if(json.error == 1){ let arr =[]; b.forEach(function(element) { if(element.checked == true){ let aid = element.getAttribute("data-aid"); let cid = element.getAttribute("data-cid"); let title = element.getAttribute("title"); let json ={ "aid": aid, "cid": cid, "title": title, }; arr.push(json); } }) if(arr.length == 0){ commonFunction.Toast("请选择需要下载的视频",3000) }else{ ControllerBilibili.bipldown(arr); } }else if(json.error == -2){ let msg =json.msg commonFunction.Toast(msg); }else { commonFunction.Toast('服务器请求失败,请重试!'); } }) }else { commonFunction.Toast('请在脚本设置里输入验证码!'); } }); let biliList = document.getElementsByClassName('bilidown'); console.log(biliList); for (var i = 0; i < biliList.length; i++) { biliList[i].addEventListener('click',function() { let aid = this.getAttribute("data-aid"); let cid = this.getAttribute("data-cid"); let title = this.getAttribute("title"); let headers = { "Content-type": "application/json" }; let request = commonFunction.request("GET","https://api.bilibili.com/x/player/playurl?avid="+aid+"&cid="+cid+"&qn=112",headers,null); request.then(function(resdata){ let obj=JSON.parse(resdata.data); if(obj.code == 0){ window.open(obj.data.durl[0].url); console.log(obj) }else{ commonFunction.Toast("获取下载链接失败"); } }) }); } }, //批量下载相关代码 bipldown:function(a){ let pldownarr=[]; for (var i = 0; i < a.length; i++) { let title =i+1+"."+a[i].title+".flv"; let headers = { "Content-type": "application/json" }; let request = commonFunction.request("GET","https://api.bilibili.com/x/player/playurl?avid="+a[i].aid+"&cid="+a[i].cid+"&qn=112",headers,null); request.then(function(resdata){ let obj=JSON.parse(resdata.data); if(obj.code == 0){ let json ={ "url": obj.data.durl[0].url, "title":title.replace(/\//g, '-'), }; pldownarr.push(json); if(pldownarr.length==a.length){ console.log(pldownarr); Controlleraria2.plaria2(-1,pldownarr); } }else{ commonFunction.Toast("获取下载链接失败"); } }) } }, }; //Bilibili下载结束 //喜马拉雅下载开始 var Controllerximalaya = { addximalaya:async function(){ // await commonFunction.sleep(3000); if(config.playhref.indexOf("www.ximalaya.com/album")!= -1){ let albumId = commonFunction.geturlid(config.playhref); let headers = { "Content-type": "application/json" }; let request = commonFunction.request("GET","https://www.ximalaya.com/revision/album/v1/getTracksList?albumId="+albumId+"&pageNum=1",headers,null); request.then(function(resdata){ let obj=JSON.parse(resdata.data); if(obj.ret == 200){ let trackTotalCount =obj.data.trackTotalCount; if(trackTotalCount<=100){ var page = 1 }else{ page =Math.ceil(trackTotalCount/100) } let arr1 =[]; return new Promise(function(resolve, reject){ recurTest(0, page,albumId,arr1); function recurTest(j,length,albumId,arr){ setTimeout(function(){ if(++j <= length){ let headers = { "Content-type": "application/json" }; let request2 = commonFunction.request("GET","https://www.ximalaya.com/revision/album/v1/getTracksList?albumId="+albumId+"&pageSize=100&pageNum="+j+"&sort=0",headers,null); request2.then(function(resdata2){ let obj=JSON.parse(resdata2.data); if(obj.ret == 200){ let tracks =obj.data.tracks; arr1 = arr.concat(tracks) console.log(arr1) recurTest(j, length,albumId,arr1); if(j==length){ resolve(arr1) }; }else{ commonFunction.Toast("获取下载列表失败"); } }); console.log(j, length,albumId) } }, Math.random() * 100); } }).then((listarr) => { let downhtml="" for (var i = 0; i < listarr.length; i++) { downhtml += '<li class="_nO"><input data-trackId="'+listarr[i].trackId+'" title="'+listarr[i].title+'" type="checkbox" style="margin-right:5px;position: relative;top: 1px;"><div class="text _nO" style="max-width: 160px;"><span style="font-size: 12px;" class="title _nO">'+listarr[i].index+'.'+listarr[i].title+'</span></div><div class="right _nO" style="margin: 0 5px;width: 35px;"><a class="ximadown" data-trackId="'+listarr[i].trackId+'" title="'+listarr[i].title+'" href="javascript:void(0)" ><span class="time _nO" style="font-size: 12px;">下载</span></a></div></li>'; } var xm= commonFunction.Commonsetinterval(".xui-card"); xm.then(function(node){ let listHTML ='<div class="xui-card" id="ximadown" style="font-family: PingFang SC, HarmonyOS_Regular, Helvetica Neue, Microsoft YaHei, sans-serif;"><div class="xui-card" style="margin-bottom: 15px;"><div style="margin: 0;" class="xui-card-head border"><span class="xui-card-head-title" style="display: block;"><i style="color: #666;" class="xuicon xuicon-quanjubofangqi-xiazai font-icon-18"></i></i>下载列表<div class="xui-card-extra"><a rel="nofollow" style="font-weight: bold;" class="xui-card-extra-title Tj_" href="javascript:void(0)"><span id="aria2set">设置</span></a></div></span></div><div style="margin: 0;max-height: 300px;overflow-y: scroll;" class="xui-card-body"><div class="sound-list H_g"><ul id="downBox">'+downhtml+'</ul></div></div><div style="display: flex;justify-content: space-between;height: 42px;line-height: 42px;font-size: 14px;font-weight: bold;"><div><span style="margin-right: 20px;" id="all">全选</span><span id="delall">重置</span></div><div><a id="pldown"><span>批量下载</span></a></div></div></div></div>'; node.insertAdjacentHTML('afterEnd',listHTML) // zhihuselect[i].insertAdjacentHTML('afterEnd',selectHtml); Controllerximalaya.ximalayadown(); }); }) } }); }else{ let list = document.getElementsByClassName('album-cover'); if(list!=null){ for (var i in list) { list[i].addEventListener('click',function() { let url =this.getAttribute("href"); const a = document.createElement('a'); document.body.appendChild(a) a.style.display = 'none' a.href = url; a.target="_blank" a.click(); window.location.reload() }) } } } }, ximalayadown:function(){ var inu = document.querySelector("#downBox"); var b=inu.querySelectorAll('input'); Controlleraria2.aria2set(b); document.querySelector("#pldown").addEventListener('click',function() { let passwordCode = commonFunction.getItem("plcode"); if (passwordCode !=""&&passwordCode !=null) { let headers = { "Content-Type": "text/html; charset=utf-8" }; let request = commonFunction.request("GET","http://tool.zhihupe.com/bdwpcs.php?m=BILIBILI&author="+author+"&PWD="+passwordCode,headers,null); request.then(function(resdata){ var json=JSON.parse(resdata.data); if(json.error == 1){ let arr =[]; b.forEach(function(element) { if(element.checked == true){ let trackId = element.getAttribute("data-trackId"); let title = element.getAttribute("title"); let json ={ "trackId": trackId, "title": title, }; arr.push(json); } }) if(arr.length == 0){ commonFunction.Toast("请选择需要下载的视频",3000) }else{ console.log(arr) Controllerximalaya.ximapldown(arr); } }else if(json.error == -2){ let msg =json.msg commonFunction.Toast(msg); }else { commonFunction.Toast('服务器请求失败,请重试!'); } }); }else { commonFunction.Toast('请在脚本设置里输入验证码!'); } }); let ximaList = document.getElementsByClassName('ximadown'); console.log(ximaList); for (var i = 0; i < ximaList.length; i++) { ximaList[i].addEventListener('click',function() { let trackId = this.getAttribute("data-trackId"); let title = this.getAttribute("title"); let passwordCode = commonFunction.getItem("plcode"); if (passwordCode !=""&&passwordCode !=null) { let headers = { "Content-type": "application/json" }; let request = commonFunction.request("GET",'https://mobile.ximalaya.com/mobile-playpage/track/v3/baseInfo/'+new Date().getTime()+'?device=web&trackId='+trackId,headers,null); request.then(function(resdata){ let obj = JSON.parse(resdata.data); console.log(obj) if(obj.ret == 0){ let downUrl = obj.trackInfo.playUrlList[0].url; let str1 = downUrl.replaceAll('-','+'); let str2 = str1.replaceAll('_','/'); let num = str2.length%4; if(num){ str2 += '===='.substr(num); } let url = CryptoJS.AES.decrypt({ ciphertext: CryptoJS.enc.Base64.parse(str2) }, CryptoJS.enc.Hex.parse("aaad3e4fd540b0f79dca95606e72bf93"), { mode: CryptoJS.mode.ECB, padding: CryptoJS.pad.Pkcs7 }).toString(CryptoJS.enc.Utf8); console.log(url); if(url){ ControllerShortvideo.ToastDwon(url,obj.trackInfo.title+'.mp3',""); }else{ commonFunction.Toast('解密地址失败'); } }else{ commonFunction.Toast("获取下载链接失败"); } }); } }); } }, ximapldown:function(arr){ let pldownarr =[] for (var i = 0; i < arr.length; i++) { let title =i+"."+arr[i].title+".mp3";; let headers = { "Content-type": "application/json" }; let request = commonFunction.request("GET",'https://mobile.ximalaya.com/mobile-playpage/track/v3/baseInfo/'+new Date().getTime()+'?device=web&trackId='+arr[i].trackId,headers,null); request.then(function(resdata){ let obj = JSON.parse(resdata.data); console.log(obj) if(obj.ret == 0){ let downUrl = obj.trackInfo.playUrlList[0].url; let str1 = downUrl.replaceAll('-','+'); let str2 = str1.replaceAll('_','/'); let num = str2.length%4; if(num){ str2 += '===='.substr(num); } let url = CryptoJS.AES.decrypt({ ciphertext: CryptoJS.enc.Base64.parse(str2) }, CryptoJS.enc.Hex.parse("aaad3e4fd540b0f79dca95606e72bf93"), { mode: CryptoJS.mode.ECB, padding: CryptoJS.pad.Pkcs7 }).toString(CryptoJS.enc.Utf8); console.log(url); url if(url){ // addUri(decrypted,title) let json ={ "url": url, "title": title, }; pldownarr.push(json) if(pldownarr.length==arr.length){ console.log(pldownarr); Controlleraria2.plaria2(-1,pldownarr); } }else{ commonFunction.Toast('解密地址失败'); } }else{ commonFunction.Toast("获取下载链接失败"); } }); } }, } //喜马拉雅下载结束 //----------------------------------------------------------------------- //脚本设置开始 if(commonFunction.IsPC()===true){ commonFunction.menusetting(); // GM_deleteValue("videosetting"); var Menu=GM_registerMenuCommand ("脚本设置", function(){ var menulist = [ {name:"VIP视频解析功能",value:"videosetting",set:commonFunction.GMgetValue("videosetting"),}, {name:"电商优惠券查询功能",value:"couponsetting",set:commonFunction.GMgetValue("couponsetting"),}, {name:"电商历史价格查询功能",value:"historysetting",set:commonFunction.GMgetValue("historysetting"),}, {name:"短视频无水印下载功能",value:"Shortvideosetting",set:commonFunction.GMgetValue("Shortvideosetting"),}, {name:"Bilibili无水印下载功能",value:"Bilibilisetting",set:commonFunction.GMgetValue("Bilibilisetting"),}, {name:"喜马拉雅下载功能",value:"Ximalayasetting",set:commonFunction.GMgetValue("Ximalayasetting"),}, ] var mainHTML = "" for(i in menulist){ let text = menulist[i].set===1?"关闭":"开启"; mainHTML += '<div style="display: flex;justify-content: space-between;font-size: 14px;height: 38px;line-height: 38px;"><div>'+menulist[i].name+'</div><button style="font-size: 14px;padding: 0px 10px;line-height: 18px;height: 28px;border: 1px solid #cacaca;border-radius: 5px;margin: 5px 0;background: #fff0;" class="s" data-name="'+menulist[i].name+'" data-value="'+menulist[i].value+'">'+text+'</button></div>' } let m = document.createElement('div'); m.innerHTML = '<h2 style="font-size: 18px;font-weight: bold;margin-bottom: 10px;line-height: 40px;">脚本功能设置</h2>'+mainHTML+'<button style="font-size: 14px;padding: 0 10px;line-height: 28px;height: 38px;border: 0;border-radius: 5px;margin: 10px 0;background: #54be99;color: #fff;width: 80px;" id="CloseMenu">关闭</button>'; console.log(m) m.setAttribute('id','Menu'); m.style.cssText = "box-shadow: 0px 0px 8px 1px rgb(98 99 99 / 34%);max-width:60%;width: 380px;padding:10px 20px;min-height: 40px;line-height: 40px;text-align: center;border-radius: 10px;position: fixed;top: 50%;left: 50%;transform: translate(-50%, -50%);z-index: 99999999;background: #fff;font-size: 16px;font-family: PingFang SC, HarmonyOS_Regular, Helvetica Neue, Microsoft YaHei, sans-serif;"; document.body.appendChild(m); let s = document.getElementsByClassName("s"); for (var i = 0; i < s.length; i++) { s[i].addEventListener('click',function() { var name = this.getAttribute("data-value"); if(commonFunction.GMgetValue(name)=== 1){ commonFunction.GMsetValue(name,0); this.innerText = "开启"; commonFunction.Toast(this.getAttribute("data-name")+"已关闭",1500); }else{ commonFunction.GMsetValue(name,1); this.innerText = "关闭"; commonFunction.Toast(this.getAttribute("data-name")+"已开启",1500); } }); } document.querySelector("#CloseMenu").addEventListener('click',function() { document.body.removeChild(document.querySelector("#Menu")); }) }, "h"); } //脚本设置结束 //------------------------------------------------------------------------- //统一判断运行 if(commonFunction.GMgetValue("isuser") == 1){ switch (config.host) { case 'v.qq.com': if(commonFunction.GMgetValue("videosetting")===1){ ControllerVideo.addbtn(); commonFunction.setItem("playwork","1"); console.log('已进入腾讯'); var mask = commonFunction.Commonsetinterval("#mask_layer"); mask.then(function(masknode){ masknode.parentNode.removeChild(masknode); }); var mod = commonFunction.Commonsetinterval(".mod_vip_popup"); mod.then(function(modnode){ modnode.parentNode.removeChild(modnode); }); var panel = commonFunction.Commonsetinterval(".panel-tip-pay"); panel.then(function(panelnode){ panelnode.parentNode.removeChild(panelnode); }); } break; case 'v.youku.com': if(commonFunction.GMgetValue("videosetting")===1){ ControllerVideo.addbtn(); console.log('已进入优酷') } break; case 'www.iqiyi.com': if(commonFunction.GMgetValue("videosetting")===1){ ControllerVideo.addbtn(); commonFunction.setItem("playwork","1"); console.log('已进入爱奇艺') } break; case 'www.mgtv.com': if(commonFunction.GMgetValue("videosetting")===1){ ControllerVideo.addbtn(); commonFunction.setItem("playwork","1"); console.log('已进入芒果TV') } break; case 'w.mgtv.com': if(commonFunction.GMgetValue("videosetting")===1){ ControllerVideo.addbtn(); commonFunction.setItem("playwork","1"); console.log('已进入芒果TV') } break; case 'www.bilibili.com': commonFunction.setItem("playwork","1"); if(commonFunction.GMgetValue("videosetting")===1){ if (config.playhref.indexOf("www.bilibili.com/bangumi/play") != -1) { ControllerVideo.addbtn(); } } if(commonFunction.GMgetValue("Bilibilisetting")===1){ var Bv = null; var pathname = window.location.pathname; if (pathname.indexOf("/medialist/play/watchlater/") != -1) { Bv = pathname.replace("/medialist/play/watchlater/","").replace("/",""); }else{ Bv = pathname.replace("/video/","").replace("/",""); } console.log(Bv) if(Bv!=null){ ControllerBilibili.Getaid(Bv); } } console.log('已进入bilibili') break; case 'www.le.com': if(commonFunction.GMgetValue("videosetting")===1){ ControllerVideo.addbtn(); commonFunction.setItem("playwork","1"); } console.log('已进入乐视TV') break; case 'film.sohu.com': if(commonFunction.GMgetValue("videosetting")===1){ ControllerVideo.addbtn(); commonFunction.setItem("playwork","1"); } console.log('已进入搜狐会员') break; case 'tv.sohu.com': if(commonFunction.GMgetValue("videosetting")===1){ ControllerVideo.addbtn(); commonFunction.setItem("playwork","1"); } console.log('已进入搜狐') break; case 'www.wasu.cn': if(commonFunction.GMgetValue("videosetting")===1){ if(config.playhref.indexOf("www.wasu.cn/Play/")!=-1){ ControllerVideo.addbtn(); }else{ ControllerVideo.addmobbtn(); } } console.log('已进入华数TV') break; case 'vip.1905.com': if(commonFunction.GMgetValue("videosetting")===1){ if(config.playhref.indexOf("vip.1905.com/play/")!=-1){ ControllerVideo.addbtn(); }else{ ControllerVideo.addmobbtn(); } } console.log('已进入1905电影网') break; case 'v.pptv.com': if(commonFunction.GMgetValue("videosetting")===1){ ControllerVideo.addbtn(); } console.log('已进入PPTV') break; case 'laisoyiba.com': var jconfirm = commonFunction.Commonsetinterval(".jconfirm-scrollpane"); jconfirm.then(function(e){ e.parentNode.removeChild(e); }); break; case 'm.v.qq.com': if(config.playhref.indexOf('/play') > -1||config.playhref.indexOf('/cover') > -1){ ControllerVideo.addmobbtn(); commonFunction.setItem("playwork","1"); var Poster = commonFunction.Commonsetinterval("#vipPosterContent"); Poster.then(function(Posternode){ Posternode.parentNode.removeChild(Posternode); }); var at = commonFunction.Commonsetinterval(".at-app-banner"); at.then(function(atnode){ atnode.parentNode.removeChild(atnode); }); console.log('已进入手机腾讯'); } break; case 'm.youku.com': var callEnd_box = commonFunction.Commonsetinterval(".callEnd_box"); callEnd_box.then(function(callEnd_boxnode){ callEnd_boxnode.parentNode.removeChild(callEnd_boxnode); }); ControllerVideo.addmobbtn(); console.log('已进入手机优酷'); break; case 'm.iqiyi.com': ControllerVideo.addmobbtn(); commonFunction.setItem("playwork","1"); console.log('已进入手机爱奇艺'); break; case 'm.mgtv.com': var mg = commonFunction.Commonsetinterval(".mg-down-btn"); mg.then(function(mgnode){ mgnode.parentNode.removeChild(mgnode); }); var fixed = commonFunction.Commonsetinterval(".ad-fixed-bar"); fixed.then(function(fixednode){ fixednode.parentNode.removeChild(fixednode); }); ControllerVideo.addmobbtn(); commonFunction.setItem("playwork","1"); console.log('已进入手机芒果TV'); break; case 'm.bilibili.com': if (config.playhref.indexOf("m.bilibili.com/bangumi/play") != -1) { ControllerVideo.addmobbtn(); commonFunction.setItem("playwork","1"); } console.log('已进入手机bilibili'); break; case 'm.le.com': ControllerVideo.addmobbtn(); commonFunction.setItem("playwork","1"); console.log('已进入手机乐视TV'); break; case 'm.tv.sohu.com': ControllerVideo.addmobbtn(); commonFunction.setItem("playwork","1"); var cover = commonFunction.Commonsetinterval(".player_film_cover"); cover.then(function(covernode){ covernode.parentNode.removeChild(covernode); }); console.log('已进入手机搜狐'); break; case 'm.pptv.com': ControllerVideo.addmobbtn(); console.log('已进入手机PPTV'); break; case 'item.taobao.com': if(commonFunction.GMgetValue("couponsetting")===1){ ControllerCoupon.Getcoupon(); } if(commonFunction.GMgetValue("historysetting")===1){ ControllerHistory.History(); } console.log('已进入淘宝'); break; case 's.taobao.com': if(commonFunction.GMgetValue("couponsetting")===1){ ControllerCoupon.taobaoso(); commonFunction.setItem("playwork","1"); } console.log('已进入淘宝搜索'); break; case 'detail.tmall.com': if(commonFunction.GMgetValue("couponsetting")===1){ ControllerCoupon.Getcoupon(); } if(commonFunction.GMgetValue("historysetting")===1){ ControllerHistory.History(); } console.log('已进入天猫'); break; case 'detail.tmall.hk': if(commonFunction.GMgetValue("couponsetting")===1){ ControllerCoupon.Getcoupon(); } if(commonFunction.GMgetValue("historysetting")===1){ ControllerHistory.History(); } console.log('已进入天猫国际'); break; case 'chaoshi.detail.tmall.com': if(commonFunction.GMgetValue("couponsetting")===1){ ControllerCoupon.Getcoupon(); } if(commonFunction.GMgetValue("historysetting")===1){ ControllerHistory.History(); } console.log('已进入天猫超市'); break; case 'list.tmall.com': ControllerCoupon.tmallso(); // setItem("playwork","1") console.log('已进入天猫搜索'); break; case 'item.yiyaojd.com': if(commonFunction.GMgetValue("couponsetting")===1){ ControllerCoupon.Getcoupon(); } if(commonFunction.GMgetValue("historysetting")===1){ ControllerHistory.History(); } console.log('已进入京东医药'); break; case 'item.jd.com': if(commonFunction.GMgetValue("couponsetting")===1){ ControllerCoupon.Getcoupon(); } if(commonFunction.GMgetValue("historysetting")===1){ ControllerHistory.History(); } console.log('已进入京东'); break; case 'npcitem.jd.hk': if(commonFunction.GMgetValue("couponsetting")===1){ ControllerCoupon.Getcoupon(); } if(commonFunction.GMgetValue("historysetting")===1){ ControllerHistory.History(); } console.log('已进入京东国际'); break; case 'www.douyin.com': console.log('已进入抖音') ; if(commonFunction.GMgetValue("Shortvideosetting")===1) { ControllerShortvideo.douyinbtn(); } break; case 'www.kuaishou.com': console.log('已进入快手') ; if(commonFunction.GMgetValue("Shortvideosetting")===1) { ControllerShortvideo.kuaishoubtn(); } break; case 'www.ixigua.com': console.log('已进入西瓜视频') ; if(commonFunction.GMgetValue("Shortvideosetting")===1) { commonFunction.setItem("playwork","1"); ControllerShortvideo.xiguabtn(); } break; case 'www.ximalaya.com': console.log('已进入喜马拉雅') ; if(commonFunction.GMgetValue("Ximalayasetting")===1) { Controllerximalaya.addximalaya(); } break; } //网站判断执行结束 }else{ let userhtml = '<div id="user" style="position: fixed;top: 50%;left: 50%;width: 480px;max-width: 80%;height: 468px;border-radius: 10px;background-image: url(https://static.hitv.com/pc/img/601d3ee.png),url(https://static.hitv.com/pc/img/21b00eb.png);background-position: 0 0,100% 280px;background-repeat: no-repeat;background-color: #fff;-webkit-box-shadow: 0 0 80px rgba(0,0,0,.25);box-shadow: 0 0 80px rgba(0,0,0,.25);opacity: 1;-webkit-transform: translate(-50%,-50%);-ms-transform: translate(-50%,-50%);transform: translate(-50%,-50%);z-index: 99999;">'; if(commonFunction.IsWap() == "wap"){ var btncss="margin: 0 20px;"; var tybtncss="width: 130px;" }else{ btncss="margin: 0 90px;"; tybtncss="width: 180px;" } userhtml += '<div style="margin-top: 45px;color: #222;font-weight: 700;font-size: 28px;text-align: center;">脚本使用协议</div>' userhtml += '<div style="width: 100%;height: 220px;margin: 35px auto 40px;overflow-x: hidden;overflow-y: scroll;">' userhtml +='<p style="margin: 0 50px 5px;color: #777;font-weight: 400;font-size: 13px;line-height: 22px;word-break: break-all;text-align: justify;"> 感谢您对本脚本的信任,为了更好的使用本脚本,在此,我们郑重提醒您:</p>' userhtml +='<p style="margin: 0 50px 5px;color: #777;font-weight: 400;font-size: 13px;line-height: 22px;word-break: break-all;text-align: justify;">1.有能力的情况,请大家支持正版</p>' userhtml +='<p style="margin: 0 50px 5px;color: #777;font-weight: 400;font-size: 13px;line-height: 22px;word-break: break-all;text-align: justify;">2.本脚本仅用学习交流,请勿用于非法、商业用途,使用本脚本下载的内容请勿进行复制、传播等侵权行为</p>' userhtml +='<p style="margin: 0 50px 5px;color: #777;font-weight: 400;font-size: 13px;line-height: 22px;word-break: break-all;text-align: justify;">3.VIP视频解析中所用到的解析接口全部收集自互联网(源码可见),版权问题请联系相关解析接口所有者,脚本不承担相关责任</p>' userhtml +='<p style="margin: 0 50px 5px;color: #777;font-weight: 400;font-size: 13px;line-height: 22px;word-break: break-all;text-align: justify;">4.视频下载内容均来自平台本身API接口,不存在破解情况,如果侵权请邮件([email protected])联系删除。</p>' userhtml +='<p style="margin: 0 50px 5px;color: #777;font-weight: 400;font-size: 13px;line-height: 22px;word-break: break-all;text-align: justify;">5.点击我同意后,即已代表您已经充分了解相关问题,否则后果自负,特此声明!</p></div>' userhtml +='<div style="display: flex;'+btncss+'justify-content: space-between;"><button style="width: 100px;height: 45px;border: none;border-radius: 25px;outline: none;color: #fff;background: #ddd;font-weight: 700;font-size: 15px;line-height: 45px;" id="bty">不同意</button> <button style="'+tybtncss+'height: 45px;border: none;border-radius: 25px;outline: none;color: #fff;background: #ffa000;background: -webkit-gradient(linear,left top,right top,from(#ff5f00),to(#ffa000));background: -webkit-linear-gradient(left,#ff5f00,#ffa000);background: -o-linear-gradient(left,#ff5f00 0,#ffa000 100%);background: linear-gradient(90deg,#ff5f00,#ffa000);font-weight: 700;font-size: 15px;line-height: 45px;" id="ty">我同意</button></div></div>' console.log(userhtml) document.body.insertAdjacentHTML('afterbegin', userhtml); document.querySelector("#ty").addEventListener('click',function() { commonFunction.GMsetValue("isuser","1"); window.location.reload(); }) document.querySelector("#bty").addEventListener('click',function() { commonFunction.GMsetValue("isuser","0"); document.body.removeChild(document.querySelector("#user")); }); } //用户协议 if (commonFunction.getItem("playwork") == 1) { setInterval(function() { var workurl = window.location.href; if (config.playhref != workurl) { console.log(workurl); config.playhref = workurl; window.location.reload() } },1000); } //监听网址 // Your code here... })();
QingJ © 2025
镜像随时可能失效,请加Q群300939539或关注我们的公众号极客氢云获取最新地址