// ==UserScript== // @name [🤣]知乎使用增强、B站哔哩哔哩使用增强、全网VIP视频免费破解去广告、全网音乐直接下载等多合一纯净脚本 // @namespace coolhii_vip // @version 4.2.5 // @description 【组合型多功能脚本,完全免费,长期维护更新】【1】知乎使用增强:外链接直接跳出、问题,回答时间标注、短视频下载方便保存等;【2】B站哔哩哔哩使用增强、番剧大会员VIP视频解析、视频下载(支持多P下载)、一键三联、浏览记录提醒;【3】全网VIP视频免费破解去广告,移动端+PC:支持爱奇艺、腾讯、芒果、优酷、哔哩哔哩等;【4】全网音乐有声音频免客户端下载,支持网易云音乐、QQ音乐、酷狗、喜马拉雅、咪咕等;【5】优惠券查询;脚本功能可独立开关,按需使用 // @author 橘子爱哭,爱画画的猫 // @icon  // @include *://wenku.baidu.com/* // @include *://*.youku.com/v_* // @include *://*.iqiyi.com/v_* // @include *://*.iqiyi.com/w_* // @include *://*.iqiyi.com/a_* // @include *://*.le.com/ptv/vplay/* // @include *://v.qq.com/x/cover/* // @include *://v.qq.com/x/page/* // @include *://v.qq.com/tv/* // @include *://*.tudou.com/listplay/* // @include *://*.tudou.com/albumplay/* // @include *://*.tudou.com/programs/view/* // @include *://*.mgtv.com/b/* // @include *://film.sohu.com/album/* // @include *://tv.sohu.com/v/* // @include *://*.bilibili.com/video/* // @include *://*.baofeng.com/play/* // @include *://vip.pptv.com/show/* // @include *://v.pptv.com/show/* // @include *://www.le.com/ptv/vplay/* // @include *://www.wasu.cn/Play/show/* // @include *://m.v.qq.com/x/cover/* // @include *://m.v.qq.com/x/page/* // @include *://m.v.qq.com/* // @include *://m.iqiyi.com/v_* // @include *://m.iqiyi.com/w_* // @include *://m.iqiyi.com/a_* // @include *://m.youku.com/alipay_video/* // @include *://https://m.youku.com/video/id_* // @include *://m.mgtv.com/b/* // @include *://m.tv.sohu.com/v/* // @include *://m.film.sohu.com/album/* // @include *://m.le.com/ptv/vplay/* // @include *://m.pptv.com/show/* // @include *://m.acfun.cn/v/* // @include *://m.bilibili.com/video/* // @include *://m.bilibili.com/anime/* // @include *://m.bilibili.com/bangumi/play/* // @include *://m.wasu.cn/Play/show/* // @include *music.163.com* // @include *://y.qq.com* // @include *://www.kugou.com* // @include *://www.kuwo.cn* // @include *://www.lizhi.fm* // @include *://*.ximalaya.com* // @include *://music.migu.cn* // @include *://item.taobao.com/* // @include *://*detail.tmall.com/* // @include *://*detail.tmall.hk/* // @include *://*product.suning.com/* // @include *://*item.jd.com/* // @include *://item.yiyaojd.com/* // @include *://npcitem.jd.hk/* // @include *://*detail.vip.com/* // @include *://*mobile.yangkeduo.com/goods* // @include *://*.zhihu.com/* // @include *://v.vzuu.com/video/* // @include *://video.zhihu.com/video/* // @include *://www.bilibili.com/** // @include *://search.bilibili.com/** // @include *://space.bilibili.com/** // @exclude *://www.bilibili.com/bangumi/** // @connect api.bilibili.com // @connect t.mimixiaoke.com // @connect t.jtm.pub // @grant GM_xmlhttpRequest // @grant GM_getResourceText // @grant GM_getValue // @grant GM_setValue // @grant GM_openInTab // @grant GM_download // @grant GM_info // @grant GM_registerMenuCommand // @require https://lf26-cdn-tos.bytecdntp.com/cdn/expire-1-M/jquery/3.2.1/jquery.min.js // @charset UTF-8 // @license AGPL License // @original-script https://greasyfork.org/zh-CN/scripts/418804 // @original-author 爱画画的猫 // @original-license AGPL License // @original-changes 已经获得原作者的完全授权,在源码使用出也做了相应版权说明,特此申明 // @antifeature referral-link // @run-at document-idle // @downloadURL none // ==/UserScript== (function () { 'use strict'; /* * 在“爱画画的猫”脚本的基础之上,做的二次开发,涉及到功能裁剪和添加,完全满足开源协议 * 脚本地址:https://greasyfork.org/zh-CN/scripts/418804 * 作者:爱画画的猫,代码已经授权 */ //共有方法,全局共享 function commonFunction(){ this.GMgetValue = function (name, value=null) { let storageValue = value; if (typeof GM_getValue === "function") { storageValue = GM_getValue(name, value); } else if(typeof GM.setValue === "function"){ storageValue = GM.getValue(name, value); }else{ var arr = window.localStorage.getItem(name); if(arr != null){ storageValue = arr } } return storageValue; }; this.GMsetValue = function(name, value){ if (typeof GM_setValue === "function") { GM_setValue(name, value); } else if(typeof GM.setValue === "function"){ GM.setValue(name, value); }else{ window.localStorage.setItem(name, value) } }; this.GMaddStyle = function(css){ var myStyle = document.createElement('style'); myStyle.textContent = css; var doc = document.head || document.documentElement; doc.appendChild(myStyle); }; this.GMopenInTab = function(url, open_in_background){ if (typeof GM_openInTab === "function") { GM_openInTab(url, open_in_background); } else { GM.openInTab(url, open_in_background); } }; this.addScript = function(url){ var s = document.createElement('script'); s.setAttribute('src',url); document.body.appendChild(s); }; this.randomNumber = function(){ return Math.ceil(Math.random()*100000000); }; this.request = function(mothed, url, param){ //网络请求 return new Promise(function(resolve, reject){ GM_xmlhttpRequest({ url: url, method: mothed, data:param, onload: function(response) { var status = response.status; var playurl = ""; if(status==200||status=='200'){ var responseText = response.responseText; resolve({"result":"success", "data":responseText}); }else{ reject({"result":"error", "data":null}); } } }); }) }; this.addCommonHtmlCss = function(){ var cssText = ` @keyframes fadeIn { 0% {opacity: 0} 100% {opacity: 1} } @-webkit-keyframes fadeIn { 0% {opacity: 0} 100% {opacity: 1} } @-moz-keyframes fadeIn { 0% {opacity: 0} 100% {opacity: 1} } @-o-keyframes fadeIn { 0% {opacity: 0} 100% {opacity: 1} } @-ms-keyframes fadeIn { 0% {opacity: 0} 100% {opacity: 1} } @keyframes fadeOut { 0% {opacity: 1} 100% {opacity: 0} } @-webkit-keyframes fadeOut { 0% {opacity: 1} 100% {opacity: 0} } @-moz-keyframes fadeOut { 0% {opacity: 1} 100% {opacity: 0} } @-o-keyframes fadeOut { 0% {opacity: 1} 100% {opacity: 0} } @-ms-keyframes fadeOut { 0% {opacity: 1} 100% {opacity: 0} } .web-toast-kkli9{ position: fixed; background: rgba(0, 0, 0, 0.7); color: #fff; font-size: 14px; line-height: 1; padding:10px; border-radius: 3px; left: 50%; transform: translateX(-50%); -webkit-transform: translateX(-50%); -moz-transform: translateX(-50%); -o-transform: translateX(-50%); -ms-transform: translateX(-50%); z-index: 999999999999999999999999999; white-space: nowrap; } .fadeOut{ animation: fadeOut .5s; } .fadeIn{ animation:fadeIn .5s; } `; this.GMaddStyle(cssText); }; this.webToast = function(params) { //小提示框 var time = params.time; var background = params.background; var color = params.color; var position = params.position; //center-top, center-bottom var defaultMarginValue = 50; if(time == undefined || time == ''){ time = 1500; } var el = document.createElement("div"); el.setAttribute("class", "web-toast-kkli9"); el.innerHTML = params.message; //背景颜色 if(background!=undefined && background!=''){ el.style.backgroundColor=background; } //字体颜色 if(color!=undefined && color!=''){ el.style.color=color; } //显示位置 if(position==undefined || position==''){ position = "center-bottom"; } //设置显示位置,当前有种两种形式 if(position==="center-bottom"){ el.style.bottom = defaultMarginValue+"px"; }else{ el.style.top = defaultMarginValue+"px"; } el.style.zIndex=999999; document.body.appendChild(el); el.classList.add("fadeIn"); setTimeout(function () { el.classList.remove("fadeIn"); el.classList.add("fadeOut"); /*监听动画结束,移除提示信息元素*/ el.addEventListener("animationend", function () { document.body.removeChild(el); }); el.addEventListener("webkitAnimationEnd", function () { document.body.removeChild(el); }); }, time); }, this.queryUrlParamter = function(text, tag) { //查询GET请求url中的参数 if(text.indexOf("?")!=-1){ //选取?后面的字符串,兼容window.location.search,前面的?不能去掉 var textArray = text.split("?"); text = "?"+textArray[textArray.length-1]; } var t = new RegExp("(^|&)" + tag + "=([^&]*)(&|$)"); var a = text.substr(1).match(t); if (a != null){ return a[2]; } return ""; }; this.isPC = function(){ var userAgentInfo = navigator.userAgent; var Agents = ["Android", "iPhone","SymbianOS", "Windows Phone", "iPad", "iPod"]; var flag = true; for (var v = 0; v < Agents.length; v++) { if (userAgentInfo.indexOf(Agents[v]) > 0) { flag = false; break; } } return flag; }; this.getBilibiliBV=function(){ var pathname = window.location.pathname; var bv = pathname.replace("/video/","").replace("/",""); return bv; } } //全局弹窗对象 const popup = (function(){ class Popup { constructor() { this.mask = document.createElement('div') this.setStyle(this.mask, { "width": '100%', "height": '100%', "backgroundColor": 'rgba(0, 0, 0, .6)', "position": 'fixed', "left": "0px", "top": "0px", "bottom":"0px", "right":"0px", "z-index":"99999" }) // 创建中间显示内容的水平并垂直居中的div this.content = document.createElement('div') this.setStyle(this.content, { "max-width": '400px', "width":"100%", "max-height": '600px', "backgroundColor": '#fff', "boxShadow": '0 0 2px #999', "position": 'absolute', "left": '50%', "top": '50%', "transform": 'translate(-50%,-50%)', "borderRadius": '3px' }) // 将这个小div放在遮罩中 this.mask.appendChild(this.content) } middleBox(param) { // 先清空中间小div的内容 - 防止调用多次,出现混乱 this.content.innerHTML = '' let title = '默认标题内容'; // 检测参数类型 if({}.toString.call(param) === '[object String]') { title = param } else if({}.toString.call(param) === '[object Object]') { title = param.title } // 将遮罩放在body中显示 document.body.appendChild(this.mask) // 给中间的小div设置默认的排版 // 上面标题部分 this.title = document.createElement('div') // 设置样式 this.setStyle(this.title, { "width": '100%', "height": '40px', "lineHeight": '40px', "boxSizing": 'border-box', "background-color":"#FF6600", "color": '#FFF', "text-align": 'center', "font-weight":"700", "font-size":"16px" }) // 设置默认标题内容 this.title.innerText = title // 将标题部分放在中间div中 this.content.appendChild(this.title) // 关闭按钮 this.closeBtn = document.createElement('div') // 设置内容 this.closeBtn.innerText = '×' // 设置样式 this.setStyle(this.closeBtn, { "textDecoration": 'none', "color": '#666', "position": 'absolute', "right": '10px', "top": '0px', "fontSize": '25px', "color": '#FFF', "display":"inline-block", "cursor":"pointer" }) // 将关闭按钮放在中间小div中 this.title.appendChild(this.closeBtn) this.closeBtn.onclick = () => this.close() } // 弹出提示框 dialog(param) { this.middleBox(param); this.dialogContent = document.createElement('div') this.setStyle(this.dialogContent,{ "padding":"15px", "max-height":"400px" }) this.dialogContent.innerHTML = param.content; this.content.appendChild(this.dialogContent) param.onContentReady(this); } close() { document.body.removeChild(this.mask) window.location.reload(); } setStyle(ele, styleObj) { // 设置样式的函数 for(let attr in styleObj){ ele.style[attr] = styleObj[attr] } } } let popup = null; return (function() { if(!popup) { popup = new Popup() } return popup; })() })(); //解析接口配置 //showType=1(仅PC), showType=2(仅mobile), showType=3(同时显示) const originalInterfaceList = [ {"name":"纯净/B站","url":"https://z1.m1907.cn/?jx=", "showType":3}, {"name":"高速接口","url":"https://jsap.attakids.com/?url=", "showType":3}, {"name":"综合/B站","url":"https://jx.bozrc.com:4433/player/?url=", "showType":3}, {"name":"OK解析","url":"https://okjx.cc/?url=", "showType":3}, {"name":"夜幕","url":"https://www.yemu.xyz/?url=", "showType":3}, {"name":"爱豆","url":"https://jx.aidouer.net/?url=", "showType":1}, {"name":"虾米","url":"https://jx.xmflv.com/?url=", "showType":1}, {"name":"M3U8.TV","url":"https://jx.m3u8.tv/jiexi/?url=", "showType":3}, {"name":"人人迷","url":"https://jx.blbo.cc:4433/?url=", "showType":3}, {"name":"全民","url":"https://jx.blbo.cc:4433/?url=", "showType":3}, {"name":"七哥","url":"https://jx.mmkv.cn/tv.php?url=", "showType":3}, {"name":"冰豆","url":"https://api.qianqi.net/vip/?url=", "showType":3}, {"name":"迪奥","url":"https://123.1dior.cn/?url=", "showType":1}, {"name":"CK","url":"https://www.ckplayer.vip/jiexi/?url=", "showType":1}, {"name":"ckmov","url":"https://www.ckmov.vip/api.php?url=", "showType":1}, {"name":"playerjy/B站","url":"https://jx.playerjy.com/?url=", "showType":3}, {"name":"ccyjjd","url":"https://ckmov.ccyjjd.com/ckmov/?url=", "showType":1}, {"name":"诺诺","url":"https://www.ckmov.com/?url=", "showType":1}, {"name":"H8","url":"https://www.h8jx.com/jiexi.php?url=", "showType":1}, {"name":"BL","url":"https://vip.bljiex.com/?v=", "showType":1}, {"name":"解析la","url":"https://api.jiexi.la/?url=", "showType":1}, {"name":"MUTV","url":"https://jiexi.janan.net/jiexi/?url=", "showType":1}, {"name":"MAO","url":"https://www.mtosz.com/m3u8.php?url=", "showType":1}, {"name":"老板","url":"https://vip.laobandq.com/jiexi.php?url=", "showType":1}, {"name":"盘古","url":"https://www.pangujiexi.cc/jiexi.php?url=", "showType":1}, {"name":"盖世","url":"https://www.gai4.com/?url=", "showType":1}, {"name":"小蒋","url":"https://www.kpezp.cn/jlexi.php?url=", "showType":1}, {"name":"YiTV","url":"https://jiexi.us/?url=", "showType":1}, {"name":"星空","url":"http://60jx.com/?url=", "showType":1}, {"name":"0523","url":"https://go.yh0523.cn/y.cy?url=", "showType":1}, {"name":"17云","url":"https://www.1717yun.com/jx/ty.php?url=", "showType":1}, {"name":"4K","url":"https://jx.4kdv.com/?url=", "showType":1}, {"name":"云析","url":"https://jx.yparse.com/index.php?url=", "showType":1}, {"name":"8090","url":"https://www.8090g.cn/?url=", "showType":1}, {"name":"江湖","url":"https://api.jhdyw.vip/?url=", "showType":1}, {"name":"诺讯","url":"https://www.nxflv.com/?url=", "showType":1}, {"name":"PM","url":"https://www.playm3u8.cn/jiexi.php?url=", "showType":1}, {"name":"听乐","url":"https://jx.dj6u.com/?url=", "showType":1}, {"name":"180","url":"https://jx.000180.top/jx/?url=", "showType":1}, {"name":"无名","url":"https://www.administratorw.com/video.php?url=", "showType":1}, {"name":"听乐(B站)","url":"https://jx.dj6u.com/?url=", "showType":2}, ]; //全局统一方法对象 const commonFunctionObject = new commonFunction(); commonFunctionObject.addCommonHtmlCss(); //统一html、css元素添加 let newOriginalInterfaceList = originalInterfaceList; //统一接口 //相关功能关闭控制 let functionController= commonFunctionObject.GMgetValue("setingData"); if(!functionController){ functionController={ "bilibiliHelper":true,"superVideoHelper":true,"superMusicHelper":true,"abroadVideoHelper":true, "wangpanSearchEnginesHelper":true,"searchEnginesNavigation":true,"zhihuHelper":true, } } //用户功能设置函数 function usersSeting(){ var bilibiliHelper=true, superVideoHelper=true, superMusicHelper=true, abroadVideoHelper=true, wangpanSearchEnginesHelper=true, searchEnginesNavigation=true, zhihuHelper=true; var isUpdateStorage = false; if(!functionController.hasOwnProperty("bilibiliHelper")){ functionController.bilibiliHelper = true; isUpdateStorage = true; }else{ bilibiliHelper = functionController.bilibiliHelper; } if(!functionController.hasOwnProperty("superVideoHelper")){ functionController.superVideoHelper = true; isUpdateStorage = true; }else{ superVideoHelper = functionController.superVideoHelper; } if(!functionController.hasOwnProperty("superMusicHelper")){ functionController.superMusicHelper = true; isUpdateStorage = true; }else{ superMusicHelper = functionController.superMusicHelper; } if(!functionController.hasOwnProperty("zhihuHelper")){ functionController.zhihuHelper = true; isUpdateStorage = true; }else{ zhihuHelper = functionController.zhihuHelper; } if(isUpdateStorage){ commonFunctionObject.GMsetValue("setingData",functionController); } var setingData=[ {"tag":"bilibiliHelper", "name":"B站使用助手(视频下载可P、浏览记录、一件三联)", "checked":bilibiliHelper}, {"tag":"zhihuHelper", "name":"知乎使用助手(内容标识、问答显示优化、视频下载等)", "checked":zhihuHelper}, {"tag":"superVideoHelper", "name":"全网VIP视频解析(支持爱奇艺、腾讯视频、B站番剧等)", "checked":superVideoHelper}, {"tag":"superMusicHelper", "name":"全网VIP音乐解析(支持网易云音乐、QQ音乐等)", "checked":superMusicHelper} ] var content = ""; for(var i=0; i ` } popup.dialog({ "title":"功能开关", "content":content, "onContentReady":function($that){ $that.dialogContent.querySelectorAll("input[type='checkbox']").forEach(function(checkbox){ checkbox.addEventListener("click", function(e){ var tag = e.target.getAttribute("data-tag"); var checked = e.target.checked; functionController[tag] = checked; commonFunctionObject.GMsetValue("setingData",functionController); commonFunctionObject.webToast({"message":"操作成功", "background":"#FF6600"}); }); }) } }); } if(commonFunctionObject.isPC()){ GM_registerMenuCommand("功能开关",()=>usersSeting()); }else{ functionController.bilibiliHelper = false; functionController.superMusicHelper = false; functionController.wangpanSearchEnginesHelper = false; functionController.searchEnginesNavigation = false; functionController.zhihuHelper = false; } /** * 超级解析助手功能 * * 原代码作者:小艾特 * 脚本地址:https://greasyfork.org/zh-CN/scripts/407847 * 视频解析接口来自,作者:懒哈哈 * 脚本地址:https://greasyfork.org/zh-CN/scripts/370634 * 遵循AGPL License开源协议 */ function superVideoHelper(originalInterfaceList){ this.originalInterfaceList = originalInterfaceList; this.elementId = Math.ceil(Math.random()*100000000)+"7899"; this.customInterfaceKey = "custom_interface_key_dddsdxxa"; this.quicklyInterfaceKey = "custom_quickly_interface_key_dddsdxxa"; this.defaultQuicklyInterfaceIndex = 1; this.isRun = function(){ //判断是否运行 const host = window.location.host; const urls = ["www.iqiyi.com","v.qq.com","youku.com", "www.le.com","mgtv.com","sohu.com", "acfun.cn","baofeng.com","pptv.com","1905.com","miguvideo.com"]; var result = false; if(!host.startsWith("m.")){ //不是移动端执行 for(var i=0; i { if(item.showType != 2){ var selected = "" if(index==quicklyInterfaceIndex){ selected = "selected"; currentQuicklyInterfaceObject = item; } category_1_html += "" + item.name + ""; } }); //获得自定义位置 var left = 0; var top = 120; var Position = commonFunctionObject.GMgetValue("Position_" + currentHost); if(!!Position){ left = Position.left; top = Position.top; } var color = "#FF6600"; var hoverColor = "#000000"; var cssMould = `#vip_movie_box`+this.elementId+`{cursor:pointer; position:fixed; top:` + top + `px; left:` + left + `px; width:0px; z-index:99999999; font-size:16px; text-align:left;} #vip_movie_box`+this.elementId+` .img_box`+this.elementId+`{width:24px;text-align:center;} #vip_movie_box`+this.elementId+` .img_box`+this.elementId+`>img {width:100%; display:inline-block; vertical-align:middle;} #vip_movie_box`+this.elementId+` .img_box`+this.elementId+`:nth-child(2){ background-color:#FF6600; border-radius:4px; margin-top:3px; } #vip_movie_box`+this.elementId+` .img_box`+this.elementId+`:nth-child(2)>img{ width:22px!important; } #vip_movie_box`+this.elementId+` .showhide_box`+this.elementId+`{display:none;padding-left:5px;position: absolute;left: 24px;top: 0;} #vip_movie_box`+this.elementId+` .vip_mod_box_action_687ii{width:380px; max-height:400px; overflow-y:auto;background-color:rgba(241,241,241);} #vip_movie_box`+this.elementId+` .default-scrollbar-55678::-webkit-scrollbar{width:5px; height:1px;} #vip_movie_box`+this.elementId+` .default-scrollbar-55678::-webkit-scrollbar-thumb{box-shadow:inset 0 0 5px rgba(0, 0, 0, 0.2); background:#A8A8A8;} #vip_movie_box`+this.elementId+` .default-scrollbar-55678::-webkit-scrollbar-track{box-shadow:inset 0 0 5px rgba(0, 0, 0, 0.2); background:#F1F1F1;} #vip_movie_box`+this.elementId+` .vip_mod_box_action_687ii> .item_box`+this.elementId+`{margin-bottom:10px;} #vip_movie_box`+this.elementId+` .vip_mod_box_action_687ii> .item_box`+this.elementId+`:last-child{margin-bottom:0px;} #vip_movie_box`+this.elementId+` .vip_mod_box_action_687ii> .item_box`+this.elementId+` >.title`+this.elementId+`{font-size:14px; text-align:left;color:#000000;font-weight:600;margin:5px 3px;} #vip_movie_box`+this.elementId+` .vip_mod_box_action_687ii> .item_box`+this.elementId+` >.interface_box`+this.elementId+`{} #vip_movie_box`+this.elementId+` .vip_mod_box_action_687ii> .item_box`+this.elementId+` >.interface_box`+this.elementId+`>span{border-radius:3px;border-top:3px solid `+color+`; border-bottom:3px solid `+color+`;display:inline-block;width:calc(25% - 6px);width:-moz-calc(25% - 6px);width: -webkit-calc(25% - 6px);height:20px;line-height:20px;background-color:`+color+`;color:#FFF;cursor:pointer;margin:3px;text-align:center;overflow:hidden;white-space: nowrap;text-overflow: ellipsis;-o-text-overflow:ellipsis;font-size:12px!important;} #vip_movie_box`+this.elementId+` .vip_mod_box_action_687ii> .item_box`+this.elementId+` >.interface_box`+this.elementId+`>span:hover{border-top:3px solid `+hoverColor+`; border-bottom:3px solid `+hoverColor+`;} #vip_movie_box`+this.elementId+` .vip_mod_box_action_687ii> .item_box`+this.elementId+` >.interface_box`+this.elementId+`>span.selected{border-top:3px solid `+hoverColor+`; border-bottom:3px solid `+hoverColor+`;} #vip_movie_box`+this.elementId+` .vip_mod_box_action_687ii> .item_box`+this.elementId+` >.content`+this.elementId+`{font-size:12px;color:#000000;margin-left:3px;} ` commonFunctionObject.GMaddStyle(cssMould); //加入HTML var htmlMould = `
接口添加
对现有接口不满意?可添加自定义接口哟~添加接口
` + category_1_html + `
免责声明:
1、VIP视频解析中所用到的解析接口全部收集自互联网(源码可见),版权问题请联系相关解析接口所有者,脚本不承担相关责任!"
2、为创造良好的创作氛围,请大家支持正版!
3、脚本仅限个人学习交流,使用即已代表您已经充分了解相关问题,否则后果自负,特此声明!
`; $("body").append(htmlMould); }; this.runEvent = function(){ //事件运行 var that = this; $("#vip_movie_box"+this.elementId+" >.plugin_inner_"+this.elementId).on("mouseover", () => { $(".showhide_box"+this.elementId).show(); }); $("#vip_movie_box"+this.elementId+" >.plugin_inner_"+this.elementId).on("mouseout", () => { $(".showhide_box"+this.elementId).hide(); }); $("body").on("click","#vip_movie_box"+this.elementId+" .vip_mod_box_action_687ii>.item_box"+this.elementId+">.interface_box"+this.elementId+">span",function(){ var index = parseInt($(this).attr("data-index")); var playObject = that.originalInterfaceList[index]; that.showPlayerWindow(playObject); $("#vip_movie_box"+that.elementId+" .vip_mod_box_action_687ii> .item_box"+that.elementId+">.interface_box"+that.elementId+">span").removeClass("selected"); $(this).addClass("selected"); commonFunctionObject.GMsetValue(that.quicklyInterfaceKey, index); $("#img_quickly_6667897iio").find("img").attr("title","快速开始(当前所选接口:"+playObject.name+")"); }); //点击视频播放界面 $("#img_box_jump_6667897iio").on("click", function(){ commonFunctionObject.GMopenInTab("https://laisoyiba.com/mov/s/?sv=3&url="+window.location.href, false); }); //点击弹出设置框 $("#img_set_6667897iio").on("click", function(){ that.showSetingDialog(); }); $("#img_quickly_6667897iio").on("click", function(){ const quicklyInterfaceIndex = that.getQuicklyInterfaceIndex(); var playObject = that.originalInterfaceList[quicklyInterfaceIndex]; that.showPlayerWindow(playObject); }); //右键移动位置 var movie_box = $("#vip_movie_box"+this.elementId); movie_box.mousedown(function(e) { if (e.which == 3) { e.preventDefault() movie_box.css("cursor", "move"); var positionDiv = $(this).offset(); var distenceX = e.pageX - positionDiv.left; var distenceY = e.pageY - positionDiv.top; $(document).mousemove(function(e) { var x = e.pageX - distenceX; var y = e.pageY - distenceY; var windowWidth = $(window).width(); var windowHeight = $(window).height(); if (x < 0) { x = 0; } else if (x > windowWidth- movie_box.outerWidth(true) - 100) { x = windowWidth - movie_box.outerWidth(true) - 100; } if (y < 0) { y = 0; } else if (y > windowHeight - movie_box.outerHeight(true)) { y = windowHeight - movie_box.outerHeight(true); } movie_box.css("left", x); movie_box.css("top", y); commonFunctionObject.GMsetValue("Position_" + window.location.host,{ "left":x, "top":y}); }); $(document).mouseup(function() { $(document).off('mousemove'); movie_box.css("cursor", "pointer"); }); $(document).contextmenu(function(e) { e.preventDefault(); }) } }); }; this.removeVideoAdBlock_iqiyi = function(){ }, this.removeVideoAdBlock_vqq = function(){ }, this.removeVideoAdBlock_youku = function(){ }, this.removeVideoAdBlock_mgtv = function(){ }, this.removeVideoAdBlock_sohu = function(){ }, this.removeVideoAdBlock = function(){ const currentHost = window.location.host; if(currentHost.indexOf("www.iqiyi.com")!=-1){ this.removeVideoAdBlock_iqiyi(); }else if(currentHost.indexOf("v.qq.com")!=-1){ this.removeVideoAdBlock_vqq(); }else if(currentHost.indexOf("v.youku.com")!=-1){ this.removeVideoAdBlock_youku(); }else if(currentHost.indexOf("www.mgtv.com")!=-1){ this.removeVideoAdBlock_mgtv(); }else if(currentHost.indexOf("tv.sohu.com")!=-1){ this.removeVideoAdBlock_sohu(); } }; this.showSetingDialog = function(){ const that = this; var customInterfaceKey = that.customInterfaceKey; var customInterface = commonFunctionObject.GMgetValue(customInterfaceKey, ""); var content = `
自定义解析接口
数据格式:[名字] + [,] + [接口地址]
例如:就是名字而已,https://jx.idc126.net/jx/?url=
注:一行一个
`; popup.dialog({ "title":"解析接口添加", "content":content, "onContentReady":function($that){ var $saveCustomInterfaceBtn = $that.dialogContent.querySelector(".save-custom-interface-btn"); $saveCustomInterfaceBtn.addEventListener("click", function(){ var $customInterfaceTextarea = $that.dialogContent.querySelector(".custom-interface-textarea"); var content = $customInterfaceTextarea.value; commonFunctionObject.GMsetValue(customInterfaceKey, content); commonFunctionObject.webToast({"message":"自定义接口保存成功", "background":"#FF6600"}); }); } }) } this.start = function(){ let delayTimeMs = 0; if(window.location.host.indexOf("www.bilibili.com")!=-1){ delayTimeMs = 2200; } setTimeout(()=>{ try{ this.removeVideoAdBlock(); }catch(e){} try{ this.analysisCustomInterface(); this.addHtmlElements(); this.runEvent(); }catch(e){} }, delayTimeMs); }; }; /** * 移动端VIP解析 * @param {Object} originalInterfaceList */ function superVideoHelperMobile(originalInterfaceList){ this.originalInterfaceList = originalInterfaceList; this.elementId = Math.ceil(Math.random()*100000000)+"mmx"; this.quicklyInterfaceKey = "custom_mobile_quickly_interface_key_dddsdxxa"; this.defaultQuicklyInterfaceIndex = 2; this.playerNodes=[ {"url":"m.iqiyi.com", "showNode":".m-video-player-wrap", "color":"#05B03B"}, {"url":"m.v.qq.com", "showNode":".mod_player", "color":"#F99D39"}, {"url":"m.youku.com", "showNode":".h5-detail-player", "color":"#08BAFD"}, {"url":"m.mgtv.com", "showNode":".video-area", "color":"#E95904"} ]; this.isRun = function(){ //判断是否运行 const host = window.location.host; const urls = ["m.iqiyi.com","m.v.qq.com","m.youku.com", "m.mgtv.com", "m.bilibili.com"]; var result = false; if(host.startsWith("m.")){ //是移动端执行 for(var i=0; i{ const elementInterval = setInterval(()=>{ const nodeElementObject = $(nodeObject.showNode), themeColor = nodeObject.color; if(nodeElementObject.length == 0) return; clearInterval(elementInterval); //添加HTML let category_1_html = ""; this.originalInterfaceList.forEach((item, index) => { if (item.showType != 1) { var selected = ""; if(index==quicklyInterfaceIndex){ selected = "selected"; } category_1_html += ""; } }); var htmlMould = `
选择解析接口
站外解析
免责申明:1、VIP视频解析中所用到的解析接口全部收集自互联网(源码可见),版权问题请联系相关解析接口所有者! 2、为创造良好的创作氛围,请大家支持正版! 3、脚本仅限个人学习交流,切勿用于任何商业等其它用途! 4、继续使用,即表明你已经明确使用脚本可能带来的风险,且愿意自行承担相关风险,对于风险脚本不承担任何责任!
`; nodeElementObject.after(htmlMould); resolve("ok"); }, 100); }); }; this.getPlayObjectBySelect = function(){ var indexString = $("#interface_selection_"+this.elementId).find("option:selected").attr("index"); var index = 0; if(!!indexString){ index = parseInt(indexString); } return this.originalInterfaceList[index]; }; this.runEvent = function(){ //事件运行 const self = this; //初始化 var playObject = self.getPlayObjectBySelect(); $('#start_analysis_outer_'+self.elementId).attr("href", playObject.url + window.location.href); $('#start_analysis_outer_'+self.elementId).on('click', function (e) { if(commonFunctionObject.GMgetValue("copyright_video_remind_mobile_outer",null)==="true"){ }else{ var r=confirm( "脚本运行提醒!!!\u000d"+ "使用站外解析功能,视频解析时脚本跳出本页面,如不同意此脚本行为,请点击【取消】按钮!!" ); if(r==false){ e.preventDefault(); }else{ commonFunctionObject.GMsetValue("copyright_video_remind_mobile_outer","true"); } } }); //接口切换 $('#interface_selection_'+self.elementId).on('change', function () { var $option = $(this).find("option:selected"); var value = $option.val(); var index = parseInt($option.attr("index")); $('#start_analysis_outer_'+self.elementId).attr("href", value+window.location.href); commonFunctionObject.GMsetValue(self.quicklyInterfaceKey, index); }); }; this.start = function(){ const self = this; if(this.isRun()){ this.addHtmlElements().then(()=>{ self.runEvent(); }); } } } /** * B站相关功能:视频多P下载,一键三联,浏览记录等 */ function bilibiliHelper(){ this.downloadVideoCoin = function(){ function innerClassDownloadVideoCoin(){ //视频下载一键三联class this.elementId = Math.ceil(Math.random()*100000000)+"mmx"; this.downloadResutError=function($btn){ $btn.text("下载视频(最高清)"); $btn.removeAttr("disabled"); }; this.downloadResutSuccess=function($btn){ $btn.text("下载视频(最高清)"); $btn.removeAttr("disabled"); }; this.getDownloadPages = function(){ return new Promise(function(resolve, reject) { var pathname = window.location.pathname, bv = null; if (pathname.indexOf("/medialist/play/watchlater/") != -1) { // 在下载视频的时候针对稍后再看页面的链接找BV号 bv = pathname.replace("/medialist/play/watchlater/","").replace("/",""); }else{ bv = pathname.replace("/video/","").replace("/",""); } if(!bv){ resolve({"status":"bv_null"}); return; } //bv转av commonFunctionObject.request("get", "http://api.bilibili.com/x/web-interface/archive/stat?bvid="+bv, null).then((resultData)=>{ let dataJson = JSON.parse(resultData.data); if(!dataJson || dataJson.code!==0 || !dataJson.data){ resolve({"status":"request_error"}); return; } let aid = dataJson.data.aid; if(!aid){ resolve({"status":"aid_null"}); return; } //获取cid commonFunctionObject.request("get", "https://api.bilibili.com/x/web-interface/view?aid="+aid, null).then((resultData2)=>{ let dataJson2 = JSON.parse(resultData2.data); if(!dataJson2 || dataJson2.code!==0 || !dataJson2.data){ resolve({"status":"request_error"}); return; } const downloadData = dataJson2.data; const aid = downloadData.aid, bvid = downloadData.bvid; const pages = new Array(); for(var i=0; i{ resolve({"status":"request_error"}); }); }).catch((errorData)=>{ resolve({"status":"request_error"}); }); }); }; this.startDownloadFile = function(aid, cid){ commonFunctionObject.request("get", "https://api.bilibili.com/x/player/playurl?avid="+aid+"&cid="+cid+"&qn=112", null).then((resultData3)=>{ let dataJson3 = JSON.parse(resultData3.data); if(!!dataJson3 && dataJson3.code===0 && !!dataJson3.data){ window.open(dataJson3.data.durl[0].url); }else{ alert("获取下载链接失败"); } }).catch((errorData)=>{ alert("获取下载链接失败"); }); }; this.createModals = function(){ var css = ` .modal-mask-`+this.elementId+`{ position:fixed; top:0; left:0; z-index:999999998; width:100%; height:100%; display:none; background-color:#000; opacity:0.3; overflow:hidden; } .modal-body-`+this.elementId+`{ position:fixed; border-radius:5px; background-color: #FFFFFF; top:10%; width:400px; max-width: 90%; max-height:170px; max-height: 600px; overflow-y: auto; z-index:999999999; left: 50%; transform: translateX(-50%); display:none; padding: 10px; } .modal-body-`+this.elementId+` >.page-wrap{ display: flex; flex-wrap: wrap; } .modal-body-`+this.elementId+` >.page-wrap >.board-item{ display: block; width: calc(50% - 10px); background-color: #6A5F60; margin: 5px; background-color:#FB7299; color:#FFFFFF; cursor: pointer; overflow:hidden; white-space:nowrap; text-overflow:ellipsis; } .modal-body-`+this.elementId+` >.modal-btn-wrap{ text-align: center; margin-top: 10px; cursor: pointer; } .modal-body-`+this.elementId+` >.copy-tips{ margin-top: 10px; font-size:12px; } `; var html = ` `; commonFunctionObject.GMaddStyle(css); $("body").append(html); }; this.hideModals = function(){ $(".modal-body-"+this.elementId+"").css('display','none'); $(".modal-mask-"+this.elementId+"").css('display','none'); }; this.showModals = function(pageHtml){ const self = this; $(".modal-body-"+self.elementId+"").css('display','block'); $(".modal-mask-"+self.elementId+"").css('display','block'); $(".modal-body-"+self.elementId+" >.page-wrap").html(pageHtml); $("body").on("click", ".modal-body-"+self.elementId+" >.page-wrap >.board-item", function(){ $(this).css("background-color","#ccc"); self.startDownloadFile($(this).data("aid"), $(this).data("cid")); }); $("body").on("click", ".modal-body-"+self.elementId+" >.modal-btn-wrap >span", function(){ self.hideModals(); }); }; this.createElementHtml = function(){ this.createModals(); //创建弹框 const randomNumber = this.elementId, self = this; let cssText = ` #bilibili_exti_`+randomNumber+`{ padding:10px; } #bilibili_exti_`+randomNumber+` >.self_s_btn{ background-color:#FB7299; color:#FFF; font-size:10px; display:inline-block; margin-right:15px; padding:2px 4px; border-radius:3px; cursor:pointer; } `; let htmlText=`
下载视频(最高清) 一键三连
`; setTimeout(()=>{ //延时的目的是让B站先加载完全 const playerInterval = setInterval(()=>{ let $viewboxReport = $("#viewbox_report div.video-data"); if($("#download_s_"+randomNumber).length==0 && $viewboxReport.length!=0){ $("body").prepend(""); $viewboxReport.append(htmlText); }else{ clearInterval(playerInterval); } }, 100); }, 2800); $("body").on("click", "#download_s_"+randomNumber, function(){ const $btn = $(this); $btn.attr("disabled", "disabled"); $btn.text("下载视频(准备中)"); //开始准备下载数据 self.getDownloadPages().then((resule)=>{ if(resule.status==="success"){ var aid = resule.downloadData.aid, pages = resule.downloadData.pages, itemHtml = ""; for(var i=0; i"+title+""; } self.showModals(itemHtml); self.downloadResutSuccess($btn); }else{ self.downloadResutError($btn); } }).catch((error)=>{ self.downloadResutError($btn); }); }); $("body").on("click", "#focus_s_"+randomNumber, function(){ $("#arc_toolbar_report .like").click(); $("#arc_toolbar_report .coin").click(); }); } this.start = function(){ let locationHost = window.location.host, locationPathname = window.location.pathname; if(locationHost==="www.bilibili.com" && (locationPathname.indexOf("/video")!=-1 || locationPathname.indexOf("/watchlater")!=-1)){ this.createElementHtml(); } } } try{ (new innerClassDownloadVideoCoin()).start(); }catch(e){ console.log("innerClassDownloadVideoCoin"+e) } }; this.recordView = function(){ //浏览记录Class function innerClassRecordView(){ this.localCacheName = "bilibili_video_record"; this.recordOneVideo = function(){ let promise = new Promise((resolve, reject)=>{ let bv = commonFunctionObject.getBilibiliBV(); let cacheText = commonFunctionObject.GMgetValue(this.localCacheName); cacheText = !cacheText ? "" : cacheText let maxLength = 12*500; let currentLength = cacheText.length; if(currentLength > maxLength){ cacheText = cacheText.substring(12*100, currentLength); } if(cacheText.indexOf(bv)==-1){ cacheText += bv; commonFunctionObject.GMsetValue(this.localCacheName, cacheText); } resolve({"result":"success"}); }); }; this.searchPageRemindHtml = function($ele, top=8, right=8){ if($ele.find("div[name='marklooked']").length==0){ $ele.css("position","relative"); $ele.append("
已看
"); } }; this.searchPageRemind = function(){ let $that = this; var elementArray = [ {"node":".video-list-item", "top":8, "right":12}, //搜索结果 {"node":"#page-index .small-item", "top":12, "right":12}, //用户投稿 {"node":"#submit-video-list .small-item", "top":12, "right":12}, //用户主页 {"node":"#page-series-detail .small-item.fakeDanmu-item", "top":12, "right":12}, //用户主页投稿 ]; setInterval(function(){ let cacheText = commonFunctionObject.GMgetValue($that.localCacheName); cacheText = !cacheText ? "" : cacheText; for(var i=0; i{ //循环操作,单独绑定 $that.searchPageRemindHtml($(this), elementobj.top, elementobj.right); }) $(this).attr("dealxll","true"); } } }); } }, 333); } this.start=function(){ let $that = this; if(window.location.pathname.indexOf("/video")!=-1 && window.location.host==="www.bilibili.com"){ let currentHref = ""; setInterval(()=>{ //需要循环存储 if(window.location.href!==currentHref){ this.recordOneVideo(); currentHref = window.location.href; } },150); } //搜索结果和用户主页已经看过的视频提醒 if(window.location.host.indexOf("bilibili.com")!=-1){ this.searchPageRemind(); GM_registerMenuCommand("清空B站浏览记录",function(){ if(confirm('是否要清空B站浏览记录?清空后将不可恢复...')){ commonFunctionObject.GMsetValue($that.localCacheName, ""); } }); } }; } try{ (new innerClassRecordView()).start(); }catch(e){ console.log("innerClassRecordView"+e) } }; this.start = function(){ this.downloadVideoCoin(); this.recordView(); } } //优惠券查询 function queryCoupon(){ this.isRun = function(){ var urls=["detail.tmall.com", "item.taobao.com", "item.jd.com", "item.yiyaojd.com", "npcitem.jd.hk", "detail.tmall.hk"]; for(var i=0; i{ this.randomSpmValue(); }, 4000); } }; this.request = function(mothed, url, param){ return new Promise(function(resolve, reject){ GM_xmlhttpRequest({ url: url, method: mothed, data:param, onload: function(response) { var status = response.status; var playurl = ""; if(status==200||status=='200'){ var responseText = response.responseText; resolve({"result":"success", "json":responseText}); }else{ reject({"result":"error", "json":null}); } } }); }) }; this.createCouponHtml = function(platform, goodsId, goodsName){ if(!platform || !goodsId) return; var goodsCouponUrl = "https://t.mimixiaoke.com/api/plugin/hit/v2?script=1&v=1.0.2&platform="+platform+"&id="+goodsId+"&q="+goodsName; var goodsPrivateUrl = "https://t.mimixiaoke.com/api/private/change/coupon?script=2&v=1.0.2&platform="+platform+"&id="; if(platform==="jd"){ goodsCouponUrl = "http://t.jtm.pub/api/platform/jd/coupon?itemId="+goodsId+"&q="+goodsName+"&content=&no=1&v=1.0.2"; goodsPrivateUrl = "http://t.jtm.pub/api/private/change/coupon?no=1&v=1.0.2&platform="+platform+"&id="; } this.request("GET", goodsCouponUrl, null).then((resutData)=>{ if(resutData.result==="success" && !!resutData.json){ var data = JSON.parse(resutData.json).data; if(!data || data==="null" || !data.css || !data.html || !data.handler){ return; } var cssText = data.css; var htmlText = data.html; var handler = data.handler; var templateId = data.templateId; if(!cssText || !htmlText || !handler){ return; } $("body").prepend(""); var handlers = handler.split("@"); for(var i=0; i{ event.stopPropagation(); event.preventDefault(); let couponId = $llkk.data("id"); if(!!couponId){ this.request("GET", goodsPrivateUrl+couponId, null).then((resutData2)=>{ if(resutData2.result==="success" && !!resutData2.json){ let url = JSON.parse(resutData2.json).url; if(!!url) GM_openInTab(url, {active:true}); } }); } }); setInterval(()=>{ $llkk.find("*").each(function(){ $(this).removeAttr("data-spm-anchor-id") }); },100); //canvas画二维码 var $canvasElement = $("#ca"+templateId); if($canvasElement.length != 0){ let couponId = $llkk.data("id"); this.request("GET", goodsPrivateUrl+couponId, null).then((resutData2)=>{ if(resutData2.result==="success" && !!resutData2.json){ let img = JSON.parse(resutData2.json).img; if(!!img){ var canvasElement = document.getElementById("ca"+templateId); var cxt = canvasElement.getContext("2d"); var imgData = new Image(); imgData.src = img; imgData.onload=function(){ cxt.drawImage(imgData, 0, 0, imgData.width, imgData.height); } } } }); } } } }); }; this.start = function(){ if(this.isRun()){ var platform = this.getPlatform(); if(!!platform){ var goodsData = this.getGoodsData(platform); this.createCouponHtml(platform, goodsData.goodsId, goodsData.goodsName); } } this.runAliDeceptionSpm(); }; } /** * 全网音乐解析下载 */ function superMusicHelper(){ this.eleId = Math.ceil(Math.random()*100000000); this.isRun = function(){ var urls=["music.163.com","y.qq.com","www.kugou.com","www.kuwo.cn","www.xiami.com","music.taihe.com","music.migu.cn","lizhi.fm","qingting.fm","ximalaya.com"]; for(var i=0; i.plugin_item{cursor:pointer; width:100%; padding:10px 0px; text-align:center;}"+ "#plugin_kiwi_analysis_vip_music_box_"+this.eleId+" >.plugin_item >img{width:20px; display:inline-block; vertical-align:middle;animation:turnaround 4s linear infinite;}"; $("body").prepend(""); }; this.generateHtml=function(){ var $that = this; var html=""; var vipImgBase64 = ""; html+= "
"; html+= "
"; html+= "
"; $("body").append(html); $("#plugin_kiwi_analysis_vip_music_box_"+this.eleId+"").on("click", function(){ var playUrl = $that.getPlayUrl(); if(!!playUrl) GM_openInTab(playUrl, false); }) }; this.operation=function(){ var $that = this; setInterval(function(){ var playUrl = $that.getPlayUrl(); var $vipMusicBox = $("#plugin_kiwi_analysis_vip_music_box_"+$that.eleId+""); if(!!playUrl){ if($vipMusicBox.length==0){ $that.generateHtml(); } }else{ $vipMusicBox.remove(); } }, 100); }; this.start=function(){ if(this.isRun()){ this.addStyle(); this.operation(); } }; } /** * 来搜一下,网盘搜索引擎无线下载 */ function wangpanSearchEnginesHelper(){ this.start = function(){ let $that = this, host = window.location.host; if(host==="www.laisoyixia.com" || host==="www.xiaozhukuaipan.com"){ var $downloadBtn = $("#downloadHandler"); var downloadurl = $downloadBtn.data("downloadurl"); if(!!downloadurl){ var wangpanUrl = window.atob(downloadurl); $downloadBtn.after("
插件提取所得:"+wangpanUrl+"
") } } } } /** * 搜索引擎资源提醒 */ function searchEnginesNavigation(){ this.searchEnginesData=[ {"host":"www.baidu.com", "element":"#content_right","elementInput":"#kw"}, {"host":"www.so.com", "element":"#side","elementInput":"#keyword"}, {"host":"www.sogou.com", "element":"#right","elementInput":"#upquery"}, {"host":"cn.bing.com", "element":"#b_context","elementInput":"#sb_form_q"}, {"host":"so.toutiao.com", "element":".s-side-list","elementInput":"input[type='search']"}, {"host":"www.google.com", "element":"#rhs","elementInput":"input[type='text']"}, ]; this.getNavigationData = function(element, elementInput){ const navigationData = [ {"name":"资源搜索","list":[ {"name":"书签搜索", "url":"https://www.bookmarkearth.com/s/search?q=@@¤tPage=1"}, {"name":"网盘搜索", "url":"https://www.xiaozhukuaipan.com/s/search?q=@@¤tPage=1"}, {"name":"财经搜索", "url":"https://www.shaduizi.com/s/search?q=@@¤tPage=1"}, {"name":"百度百科", "url":"https://baike.baidu.com/item/@@"}, {"name":"知乎搜索", "url":"https://www.zhihu.com/search?type=content&q=@@"}, {"name":"B站搜索", "url":"https://search.bilibili.com/all?keyword=@@&from_source=webtop_search&spm_id_from=333.851"}, {"name":"抖音搜索", "url":"https://www.douyin.com/search/@@?aid=0a9fc74b-01e8-4fb0-9509-307c5c07fda1&publish_time=0&sort_type=0&source=normal_search&type=general"}, {"name":"搜狗|公众号", "url":"https://weixin.sogou.com/weixin?type=2&query=@@"}, {"name":"搜狗|知乎", "url":"https://www.sogou.com/sogou?pid=sogou-wsse-ff111e4a5406ed40&insite=zhihu.com&ie=utf8&p=73351201&query=@@&ie=utf8&p=73351201&query=@@"}, {"name":"豆瓣搜索", "url":"https://www.douban.com/search?q=@@"}, {"name":"电影搜索", "url":"https://www.cupfox.com/search?key=@@"}, {"name":"维基百科", "url":"https://en.wikipedia.org/w/index.php?search=@@"}, {"name":"法律法规", "url":"https://www.pkulaw.com/law/chl?Keywords=@@"}, {"name":"PPT搜索", "url":"https://www.chuliansheji.com/s/search?q=@@¤tPage=1&c=1"}, {"name":"icon搜索", "url":"https://www.iconfont.cn/search/index?searchType=icon&q=@@"}, {"name":"github", "url":"https://github.com/search?q=@@"}, {"name":"csdn", "url":"https://so.csdn.net/so/search?q=@@&t=&u="}, {"name":"手机用油猴", "url":"https://blog.csdn.net/haoning7788/article/details/125344294"} ]}, {"name":"搜索引擎","list":[ {"name":"百度", "url":"https://www.baidu.com/s?wd=@@"}, {"name":"必应", "url":"https://cn.bing.com/search?q=@@"}, {"name":"Google", "url":"https://www.google.com/search?q=@@"}, {"name":"360搜索", "url":"https://www.so.com/s?ie=utf-8&fr=none&src=360sou_newhome&nlpv=basest&q=@@"}, {"name":"搜狗", "url":"https://www.sogou.com/web?query=@@"}, {"name":"头条搜索", "url":"https://so.toutiao.com/search?dvpf=pc&source=input&keyword=@@"} ]} ]; const $that = this; const cacheNavigationData = commonFunctionObject.GMgetValue("navigation_data_cache",null); if(!!cacheNavigationData){ $that.createHtml(element, elementInput, cacheNavigationData); }else{ $that.createHtml(element, elementInput, navigationData); } //判断值是否有变动,如果有变动就更新换存,简单处理,长度是否一致 commonFunctionObject.request("get", "http://api.staticj.top/script/api/get/navigation_json_url", null).then((resultData)=>{ let dataJson = JSON.parse(resultData.data); if(!!dataJson && !!dataJson.url){ commonFunctionObject.request("get", dataJson.url, null).then((resultData2)=>{ let serverNavigationData = resultData2.data; if(!cacheNavigationData || (!!cacheNavigationData && serverNavigationData.length!=JSON.stringify(cacheNavigationData).length)){ commonFunctionObject.GMsetValue("navigation_data_cache", JSON.parse(serverNavigationData)); } }).catch(()=>{}); } }).catch(()=>{}); }; this.createCss = function(elementNum){ var innnerCss = ` .ddfdfd`+elementNum+`dffssqa{ margin-top:15px; } .ddfdfd`+elementNum+`dffssqa:nth-last{ margin-top:0px; } .ddfdfd`+elementNum+`dffssqa>.title{ font-size:16px; } .ddfdfd`+elementNum+`dffssqa>.content-list{ } .ddfdfd`+elementNum+`dffssqa>.content-list>a{ display:inline-block; width:calc(25% - 16px); border:1px solid #ccc; border-radius:4px; text-align:center; margin-right:15px; margin-top:6px; overflow: hidden; white-space: nowrap; text-overflow:ellipsis; padding:2px; box-sizing:border-box; font-size:13px; line-height:20px; } .ddfdfd`+elementNum+`dffssqa>.content-list>a:nth-child(4n){ margin-right:0px; } `; if($("#plugin_css_style_dddsoo").length==0){ $("body").prepend(""); } }; this.createHtml = function(element, elementInput, navigationData){ $("#dsdsd99mmmjj7760011").remove(); var isComplate = true; const host = window.location.host; const self = this; const elementNum = commonFunctionObject.randomNumber(); const elementInterval = setInterval(function(){ if(isComplate){ var $element = $(element); var $box = $("#dsdsd99mmmjj7760011"); isComplate = false; if($element.length!=0 && $box.length==0){ var html = ""; html += "
"; for(var i=0; i"; html += "
"+navigationData[i].name+"
"; html += "
"; for(var j=0;j"+name+"" } html += "
"; html += "
"; } html += ""; html += ""; //添加css 添加html self.createCss(elementNum); $element.prepend(html); $("#dsdsd99mmmjj7760011 a").on("click", function(e){ commonFunctionObject.GMopenInTab($(this).data("url").replace("@@",$(elementInput).val()),false); e.preventDefault() }); } isComplate = true; } }, 100); }; this.show = function(){ const self = this; const host = window.location.host; const href = window.location.href; if((host==="www.baidu.com") || (host==="www.so.com" && href.indexOf("www.so.com/s")!=-1) || (host==="www.sogou.com" && href.indexOf("www.sogou.com/web?query")!=-1) || (host==="cn.bing.com" && href.indexOf("cn.bing.com/search")!=-1) || (host==="so.toutiao.com" && href.indexOf("so.toutiao.com/search")!=-1) || (host==="www.google.com" && href.indexOf("www.google.com/search")!=-1)){ let currentSearchEnginesData = null; for(var i=0; i创建于: ${createDate}

编辑于: ${editDate}

`; timeDiv.style.cssText = 'color:#6f6f6f;font-size:13px;'; side.appendChild(timeDiv); } } /** * 为回答添加创建时间和编辑时间 */ function addTimeAnswerItems() { var list = document.querySelectorAll(".AnswerItem"); for (var i = 0; i < list.length; i++) { var item = list[i]; if (item.getAttribute('zh_date_mk') === 'true') { continue; } item.setAttribute('zh_date_mk', 'true'); try{ var dateCreated = item.querySelector("[itemprop~=dateCreated][content]").content; var dateModified = item.querySelector("[itemprop~=dateModified][content]").content; var createDate = DateFormat(new Date(dateCreated), "yyyy-MM-dd hh:mm:ss"); var editDate = DateFormat(new Date(dateModified), "yyyy-MM-dd hh:mm:ss"); var sideItem = item.querySelector(".ContentItem-meta"); var timeDiv = document.createElement('div'); timeDiv.innerHTML = `创建于: ${createDate}   编辑于: ${editDate}`; timeDiv.class = "Voters"; timeDiv.style.cssText = 'color:#6f6f6f;font-size:13px;display:block;padding:5px 0px;'; sideItem.appendChild(timeDiv); }catch(e){} } } addDateQuestion(); setInterval(function(){ //循环检查回答和修改时间 addTimeAnswerItems(); },400); }; this.showQuestionAuthor = function(){ //此处代码借鉴自 - 知乎增强 //原作者:X.I.U //https://greasyfork.org/zh-CN/scripts/419081-%E7%9F%A5%E4%B9%8E%E5%A2%9E%E5%BC%BA if (document.querySelector('.BrandQuestionSymbol, .QuestionAuthor')) return let qJson = JSON.parse(document.querySelector('#js-initialData').textContent).initialState.entities.questions[/\d+/.exec(location.pathname)[0]].author, html = ``; document.querySelector('.QuestionHeader-topics').insertAdjacentHTML('beforebegin', html); }; this.autoHeightQualityPic = function(){ setInterval(function(){ $("body").find("img").each(function(){ var dataoriginal = $(this).attr("data-original"); if(!!dataoriginal){ $(this).attr("src", dataoriginal); } }); }, 500); }; this.downloadVideo = function(){ let downloadElementId = "zhihu_helper_666wwi1"; //有借鉴懒哈哈的脚本 //脚本地址:https://greasyfork.org/zh-CN/scripts/370634 document.addEventListener('DOMNodeInserted',(e) => { let downloadElementClassName = "zhihu_helper_666wwi1"; //有借鉴懒哈哈的脚本 //脚本地址:https://greasyfork.org/zh-CN/scripts/370634 document.addEventListener('DOMNodeInserted',(e) => { if(!e.relatedNode.querySelector) return; var playBar = e.relatedNode.querySelector(':scope > div:last-child > div:first-child > div:nth-of-type(2)'); if(!playBar || playBar.querySelector('.'+downloadElementClassName)) return; var playBut = playBar.querySelector(':scope > div:last-child'); if(!playBut) return; var playButLi = playBut.querySelector('div:first-child'); if(!playButLi) return; var downloadBut = playButLi.cloneNode(true); downloadBut.className = playButLi.className + ' ' + downloadElementClassName; if(!downloadBut.querySelector('._1tg8oir')) return; downloadBut.querySelector('._1tg8oir').innerText='下载'; playButLi.before(downloadBut); downloadBut.addEventListener("click",function(){ let playUrl = document.querySelector("video").getAttribute("src"); if(!!playUrl){ commonFunctionObject.GMopenInTab(playUrl, false); } }); }); }); }; this.start = function(){ const host = window.location.host; const self = this; if(host == "link.zhihu.com"){ this.autoJumpTarget(); } if(host.indexOf("zhihu.com")!=-1){ if(window.location.href.indexOf("www.zhihu.com/question/")!=-1){ this.markQuestionDate(); //问题日期 this.showQuestionAuthor(); //提问者标识出来 } this.markArticleOrQuestion(); //标识文章还是提问 this.autoHeightQualityPic(); //自动高清图 this.downloadVideo(); //知乎视频下载 window.onload=function(){ self.downloadVideo(); //知乎视频下载 } window.onscroll = function(){ var scrollTop = document.documentElement.scrollTop; if(scrollTop > 200){ self.downloadVideo(); //知乎视频下载 } } } }; } //最后统一调用 try{ if(functionController.superVideoHelper){ const superVideoHelperObject = new superVideoHelper(newOriginalInterfaceList); if(superVideoHelperObject.isRun()){ if(commonFunctionObject.GMgetValue("copyright_video_remind",null)==="true"){ superVideoHelperObject.start(); }else{ var r=confirm( "脚本运行提醒!!!\u000d"+ "1、VIP视频解析中所用到的解析接口全部收集自互联网(源码可见),版权问题请联系相关解析接口所有者!\u000d"+ "2、为创造良好的创作氛围,请大家支持正版!\u000d"+ "3、脚本仅限个人学习交流,切勿用于任何商业等其它用途!\u000d"+ "4、继续使用,即表明你已经明确使用脚本可能带来的风险,且愿意自行承担相关风险,对于风险脚本不承担任何责任!\u000d"+ "5、此提醒只弹出一次,确认后,后续将不在弹出,请知悉!" ); if(r==true){ commonFunctionObject.GMsetValue("copyright_video_remind","true"); superVideoHelperObject.start(); } } } (new superVideoHelperMobile(newOriginalInterfaceList)).start(); } }catch(e){ console.log("全网VIP解析:error:"+e); } try{ (new queryCoupon()).start(); }catch(e){ console.log("优惠券查询:error:"+e); } try{ if(functionController.superMusicHelper){ (new superMusicHelper()).start(); } }catch(e){ console.log("全网音乐下载:error:"+e); } try{ if(functionController.bilibiliHelper){ new bilibiliHelper(commonFunctionObject).start(); } }catch(e){ console.log("B站视频下载:error:"+e); } try{ if(functionController.zhihuHelper){ new zhihuHelper(commonFunctionObject).start(); } }catch(e){ console.log("知乎助手:error:"+e); } })();