// ==UserScript== // @name B站哔哩哔哩使用增强,全网VIP视频免费破解去广告,知乎使用增强,短视频无水印下载,油管、Facebook等国外视频解析下载等 // @namespace super_video_helper_cat // @version 5.2.26 // @description 【❤️视频解析❤️,适配PC+移动 】1、B站使用增强:支持视频下载(👉支持多P批量快速下载👈)、浏览记录提示、一键三连、自动签到、描述文本网址转链接等;2、全网VIP视频解析:爱奇艺、腾讯、优酷、bilibili等视频免费解析(支持自定义解析接口);3、知乎使用助手:内容种类标识、问答显示优化、视频下载等;4、短视频去水印下载:支持知乎、抖音、快手等;5、油管、Facebook、Tiktok等国外视频解析下载;🔥6、搜索引擎功能增强,百度添加网址显示,google结果新标签页打开灯,导航可自定义网址【脚本长期维护更新,完全免费,无广告,仅限学习交流!!】 // @author 红红火火 // @icon  // @include *://*.youku.com/v_* // @include *://*.iqiyi.com/v_* // @include *://*.iqiyi.com/w_* // @include *://*.iqiyi.com/a_* // @include *://*.iqiyi.com/resource/pcw/play/* // @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 *://*.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 *://*.1905.com/video/* // @include *://*.1905.com/play/* // @include *://*.1905.com/*/play/* // @include *://www.miguvideo.com/mgs/* // @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 *://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.wasu.cn/Play/show/* // @include *://www.baidu.com/* // @include *://www.so.com/s* // @include *://www.sogou.com/web* // @include *://www.sogou.com/sogou* // @include *://cn.bing.com/search* // @include *://www.bing.com/search* // @include *://www4.bing.com/search* // @include *://so.toutiao.com/search* // @include *://www.google.com/search* // @include *://www.google.com.hk/search* // @include *://duckduckgo.com* // @include *://www.bilibili.com/** // @include *://search.bilibili.com/** // @include *://space.bilibili.com/** // @include *://www.bilibili.com/read/** // @include *://*.zhihu.com/* // @include *://www.douyin.com/* // @include *://*.douyinvod.com/* // @include *://www.kuaishou.com/* // @include *://www.tiktok.com/@* // @include *://www.youtube.com/watch** // @include *://www.youtube.com/shorts** // @include *://*.taobao.com/* // @include *://*.tmall.com/* // @include *://*.tmall.hk/* // @include *://*.liangxinyao.com/* // @include *://chaoshi.detail.tmall.com/* // @include *://pages.tmall.com/wow/an/cs/search** // @include *://*.jd.com/* // @include *://*.jd.hk/* // @include *://item.jingdonghealth.cn/* // @include *://item.jkcsjd.com/* // @include *://*.yiyaojd.com/* // @include *://www.vipglobal.hk // @include *://*.vip.com/* // @include *://detail.vip.com/detail-* // @include *://www.vipglobal.hk/detail-* // @include *://category.vip.com/suggest.php** // @include *://list.vip.com/*.html // @include *://*.suning.com/* // @include *://*.cloud.tencent.com/* // @include *://cloud.tencent.com/* // @include *://*.huaweicloud.com/* // @include *://*.aliyun.com/* // @include /^https:\/\/([\w-]+\.)?cex\.[\w.-]+([/?#].*)?$/ // @include /^https:\/\/([\w-]+\.)?changelly\.[\w.-]+([/?#].*)?$/ // @include /^https:\/\/([\w-]+\.)?kucoin\.[\w.-]+([/?#].*)?$/ // @include /^https:\/\/([\w-]+\.)?paxful\.[\w.-]+([/?#].*)?$/ // @include /^https:\/\/([\w-]+\.)?htx\.[\w.-]+([/?#].*)?$/ // @include /^https:\/\/([\w-]+\.)?mexc\.[\w.-]+([/?#].*)?$/ // @include /^https:\/\/([\w-]+\.)?coinmama\.[\w.-]+([/?#].*)?$/ // @include /^https:\/\/([\w-]+\.)?gate\.[\w.-]+([/?#].*)?$/ // @include /^https:\/\/([\w-]+\.)?bitget\.[\w.-]+([/?#].*)?$/ // @include /^https:\/\/([\w-]+\.)?freebitco\.[\w.-]+([/?#].*)?$/ // @include /^https:\/\/([\w-]+\.)?bybit\.[\w.-]+([/?#].*)?$/ // @include /^https:\/\/([\w-]+\.)?crypto\.[\w.-]+([/?#].*)?$/ // @include /^https:\/\/([\w-]+\.)?okx\.[\w.-]+([/?#].*)?$/ // @include /^https:\/\/([\w-]+\.)?coinbase\.[\w.-]+([/?#].*)?$/ // @include /^https:\/\/([\w-]+\.)?binance\.[\w.-]+([/?#].*)?$/ // @include /^https:\/\/([\w-]+\.)?wazirx\.[\w.-]+([/?#].*)?$/ // @include /^https:\/\/([\w-]+\.)?coindcx\.[\w.-]+([/?#].*)?$/ // @include /^https:\/\/([\w-]+\.)?zebpay\.[\w.-]+([/?#].*)?$/ // @include /^https:\/\/([\w-]+\.)?bitbns\.[\w.-]+([/?#].*)?$/ // @include /^https:\/\/([\w-]+\.)?cloudways\.[\w.-]+([/?#].*)?$/ // @include /^https:\/\/([\w-]+\.)?getresponse\.[\w.-]+([/?#].*)?$/ // @include /^https:\/\/([\w-]+\.)?bandwagonhost\.[\w.-]+([/?#].*)?$/ // @include /^https:\/\/([\w-]+\.)?moosend\.[\w.-]+([/?#].*)?$/ // @include /^https:\/\/([\w-]+\.)?domainracer\.[\w.-]+([/?#].*)?$/ // @include /^https:\/\/([\w-]+\.)?namesilo\.[\w.-]+([/?#].*)?$/ // @include /^https:\/\/([\w-]+\.)?digitalocean\.[\w.-]+([/?#].*)?$/ // @include /^https:\/\/([\w-]+\.)?virmach\.[\w.-]+([/?#].*)?$/ // @include /^https:\/\/([\w-]+\.)?vultr\.[\w.-]+([/?#].*)?$/ // @exclude *://cloud.tencent.com/login* // @exclude *://console.cloud.tencent.com/* // @exclude *://market.cloud.tencent.com/* // @exclude *://www.aliyun.com/smarter-engine/* // @exclude *://account.aliyun.com/* // @exclude *://developer.aliyun.com/* // @exclude *://promotion.aliyun.com/* // @exclude *://free.aliyun.com/* // @exclude *://summit.aliyun.com/* // @exclude *://startup.aliyun.com/* // @exclude *://university.aliyun.com/* // @exclude *://careers.aliyun.com/* // @exclude *://market.aliyun.com/* // @exclude *://yunqi.aliyun.com/* // @exclude *://help.aliyun.com/* // @exclude *://g.alicdn.com/* // @exclude *://passport.aliyun.com/* // @exclude *://*.console.aliyun.com/* // @exclude *://auth.huaweicloud.com/* // @exclude *://support.huaweicloud.com/* // @exclude *://console.huaweicloud.com/* // @exclude *://jianghu.taobao.com/* // @exclude *://login.taobao.com/* // @exclude *://uland.taobao.com/* // @exclude *://map.taobao.com/* // @exclude *://creator.guanghe.taobao.com/* // @exclude *://myseller.taobao.com/* // @exclude *://qn.taobao.com/* // @exclude *://jingfen.jd.com/* // @exclude *://passport.jd.com/* // @exclude *://jmw.jd.com/* // @exclude *://passport.shop.jd.com/* // @exclude *://passport.vip.com/* // @exclude *://huodong.taobao.com/wow/z/guang/gg_publish/* // @exclude *://loginmyseller.taobao.com/* // @exclude *://accounts.youtube.com/* // @exclude *://www.youtube.com/live_chat_replay* // @exclude *://www.youtube.com/persist_identity* // @exclude *://passport.suning.com/* // @connect bilibili.com // @connect staticj.top // @connect tikdownloader.io // @connect mimixiaoke.com // @connect jiayoushichang.com // @grant unsafeWindow // @grant GM_openInTab // @grant GM.openInTab // @grant GM_getValue // @grant GM.getValue // @grant GM_setValue // @grant GM.setValue // @grant GM_addStyle // @grant GM_xmlhttpRequest // @grant GM.xmlHttpRequest // @grant GM_addStyle // @grant GM_registerMenuCommand // @grant GM_addElement // @license AGPL License // @charset UTF-8 // @run-at document-idle // ==/UserScript== /** * findAndReplaceDOMText v 0.4.6 * @author James Padolsey http://james.padolsey.com * @license http://unlicense.org/UNLICENSE * * Matches the text of a DOM node against a regular expression * and replaces each match (or node-separated portions of the match) * in the specified element. */ (function (root, factory) { if (typeof module === "object" && module.exports) { // Node/CommonJS module.exports = factory(); } else if (typeof define === "function" && define.amd) { // AMD. Register as an anonymous module. define(factory); } else { // Browser globals root.findAndReplaceDOMText = factory(); } })(this, function factory() { var PORTION_MODE_RETAIN = "retain"; var PORTION_MODE_FIRST = "first"; var doc = document; var hasOwn = {}.hasOwnProperty; function escapeRegExp(s) { return String(s).replace(/([.*+?^=!:${}()|[\]\/\\])/g, "\\$1"); } function exposed() { // Try deprecated arg signature first: return ( deprecated.apply(null, arguments) || findAndReplaceDOMText.apply(null, arguments) ); } function deprecated(regex, node, replacement, captureGroup, elFilter) { if (node && !node.nodeType && arguments.length <= 2) { return false; } var isReplacementFunction = typeof replacement == "function"; if (isReplacementFunction) { replacement = (function (original) { return function (portion, match) { return original(portion.text, match.startIndex); }; })(replacement); } // Awkward support for deprecated argument signature (<0.4.0) var instance = findAndReplaceDOMText(node, { find: regex, wrap: isReplacementFunction ? null : replacement, replace: isReplacementFunction ? replacement : "$" + (captureGroup || "&"), prepMatch: function (m, mi) { // Support captureGroup (a deprecated feature) if (!m[0]) throw "findAndReplaceDOMText cannot handle zero-length matches"; if (captureGroup > 0) { var cg = m[captureGroup]; m.index += m[0].indexOf(cg); m[0] = cg; } m.endIndex = m.index + m[0].length; m.startIndex = m.index; m.index = mi; return m; }, filterElements: elFilter, }); exposed.revert = function () { return instance.revert(); }; return true; } /** * findAndReplaceDOMText * * Locates matches and replaces with replacementNode * * @param {Node} node Element or Text node to search within * @param {RegExp} options.find The regular expression to match * @param {String|Element} [options.wrap] A NodeName, or a Node to clone * @param {String} [options.wrapClass] A classname to append to the wrapping element * @param {String|Function} [options.replace=''] What to replace each match with * @param {Function} [options.filterElements] A Function to be called to check whether to * process an element. (returning true = process element, * returning false = avoid element) */ function findAndReplaceDOMText(node, options) { return new Finder(node, options); } exposed.NON_PROSE_ELEMENTS = { br: 1, hr: 1, // Media / Source elements: script: 1, style: 1, img: 1, video: 1, audio: 1, canvas: 1, svg: 1, map: 1, object: 1, // Input elements input: 1, textarea: 1, select: 1, option: 1, optgroup: 1, button: 1, }; exposed.NON_CONTIGUOUS_PROSE_ELEMENTS = { // Elements that will not contain prose or block elements where we don't // want prose to be matches across element borders: // Block Elements address: 1, article: 1, aside: 1, blockquote: 1, dd: 1, div: 1, dl: 1, fieldset: 1, figcaption: 1, figure: 1, footer: 1, form: 1, h1: 1, h2: 1, h3: 1, h4: 1, h5: 1, h6: 1, header: 1, hgroup: 1, hr: 1, main: 1, nav: 1, noscript: 1, ol: 1, output: 1, p: 1, pre: 1, section: 1, ul: 1, // Other misc. elements that are not part of continuous inline prose: br: 1, li: 1, summary: 1, dt: 1, details: 1, rp: 1, rt: 1, rtc: 1, // Media / Source elements: script: 1, style: 1, img: 1, video: 1, audio: 1, canvas: 1, svg: 1, map: 1, object: 1, // Input elements input: 1, textarea: 1, select: 1, option: 1, optgroup: 1, button: 1, // Table related elements: table: 1, tbody: 1, thead: 1, th: 1, tr: 1, td: 1, caption: 1, col: 1, tfoot: 1, colgroup: 1, }; exposed.NON_INLINE_PROSE = function (el) { return hasOwn.call( exposed.NON_CONTIGUOUS_PROSE_ELEMENTS, el.nodeName.toLowerCase() ); }; // Presets accessed via `options.preset` when calling findAndReplaceDOMText(): exposed.PRESETS = { prose: { forceContext: exposed.NON_INLINE_PROSE, filterElements: function (el) { return !hasOwn.call( exposed.NON_PROSE_ELEMENTS, el.nodeName.toLowerCase() ); }, }, }; exposed.Finder = Finder; /** * Finder -- encapsulates logic to find and replace. */ function Finder(node, options) { var preset = options.preset && exposed.PRESETS[options.preset]; options.portionMode = options.portionMode || PORTION_MODE_RETAIN; if (preset) { for (var i in preset) { if (hasOwn.call(preset, i) && !hasOwn.call(options, i)) { options[i] = preset[i]; } } } this.node = node; this.options = options; // Enable match-preparation method to be passed as option: this.prepMatch = options.prepMatch || this.prepMatch; this.reverts = []; this.matches = this.search(); if (this.matches.length) { this.processMatches(); } } Finder.prototype = { /** * Searches for all matches that comply with the instance's 'match' option */ search: function () { var match; var matchIndex = 0; var offset = 0; var regex = this.options.find; var textAggregation = this.getAggregateText(); var matches = []; var self = this; regex = typeof regex === "string" ? RegExp(escapeRegExp(regex), "g") : regex; matchAggregation(textAggregation); function matchAggregation(textAggregation) { for (var i = 0, l = textAggregation.length; i < l; ++i) { var text = textAggregation[i]; if (typeof text !== "string") { // Deal with nested contexts: (recursive) matchAggregation(text); continue; } if (regex.global) { while ((match = regex.exec(text))) { matches.push(self.prepMatch(match, matchIndex++, offset)); } } else { if ((match = text.match(regex))) { matches.push(self.prepMatch(match, 0, offset)); } } offset += text.length; } } return matches; }, /** * Prepares a single match with useful meta info: */ prepMatch: function (match, matchIndex, characterOffset) { if (!match[0]) { throw new Error( "findAndReplaceDOMText cannot handle zero-length matches" ); } match.endIndex = characterOffset + match.index + match[0].length; match.startIndex = characterOffset + match.index; match.index = matchIndex; return match; }, /** * Gets aggregate text within subject node */ getAggregateText: function () { var elementFilter = this.options.filterElements; var forceContext = this.options.forceContext; return getText(this.node); /** * Gets aggregate text of a node without resorting * to broken innerText/textContent */ function getText(node) { if (node == null) { return []; } if (node.nodeType === Node.TEXT_NODE) { return [node.data]; } if (elementFilter && !elementFilter(node)) { return []; } var txt = [""]; var i = 0; if ((node = node.firstChild)) do { if (node.nodeType === Node.TEXT_NODE) { txt[i] += node.data; continue; } var innerText = getText(node); if ( forceContext && node.nodeType === Node.ELEMENT_NODE && (forceContext === true || forceContext(node)) ) { txt[++i] = innerText; txt[++i] = ""; } else { if (typeof innerText[0] === "string") { // Bridge nested text-node data so that they're // not considered their own contexts: // I.e. ['some', ['thing']] -> ['something'] txt[i] += innerText.shift(); } if (innerText.length) { txt[++i] = innerText; txt[++i] = ""; } } } while ((node = node.nextSibling)); return txt; } }, /** * Steps through the target node, looking for matches, and * calling replaceFn when a match is found. */ processMatches: function () { var matches = this.matches; var node = this.node; var elementFilter = this.options.filterElements; var startPortion, endPortion, innerPortions = [], curNode = node, match = matches.shift(), atIndex = 0, // i.e. nodeAtIndex matchIndex = 0, portionIndex = 0, doAvoidNode, nodeStack = [node]; out: while (true) { if (curNode.nodeType === Node.TEXT_NODE) { if (!endPortion && curNode.length + atIndex >= match.endIndex) { // We've found the ending // (Note that, in the case of a single portion, it'll be an // endPortion, not a startPortion.) endPortion = { node: curNode, index: portionIndex++, text: curNode.data.substring( match.startIndex - atIndex, match.endIndex - atIndex ), // If it's the first match (atIndex==0) we should just return 0 indexInMatch: atIndex === 0 ? 0 : atIndex - match.startIndex, indexInNode: match.startIndex - atIndex, endIndexInNode: match.endIndex - atIndex, isEnd: true, }; } else if (startPortion) { // Intersecting node innerPortions.push({ node: curNode, index: portionIndex++, text: curNode.data, indexInMatch: atIndex - match.startIndex, indexInNode: 0, // always zero for inner-portions }); } if (!startPortion && curNode.length + atIndex > match.startIndex) { // We've found the match start startPortion = { node: curNode, index: portionIndex++, indexInMatch: 0, indexInNode: match.startIndex - atIndex, endIndexInNode: match.endIndex - atIndex, text: curNode.data.substring( match.startIndex - atIndex, match.endIndex - atIndex ), }; } atIndex += curNode.data.length; } doAvoidNode = curNode.nodeType === Node.ELEMENT_NODE && elementFilter && !elementFilter(curNode); if (startPortion && endPortion) { curNode = this.replaceMatch( match, startPortion, innerPortions, endPortion ); // processMatches has to return the node that replaced the endNode // and then we step back so we can continue from the end of the // match: atIndex -= endPortion.node.data.length - endPortion.endIndexInNode; startPortion = null; endPortion = null; innerPortions = []; match = matches.shift(); portionIndex = 0; matchIndex++; if (!match) { break; // no more matches } } else if ( !doAvoidNode && (curNode.firstChild || curNode.nextSibling) ) { // Move down or forward: if (curNode.firstChild) { nodeStack.push(curNode); curNode = curNode.firstChild; } else { curNode = curNode.nextSibling; } continue; } // Move forward or up: while (true) { if (curNode.nextSibling) { curNode = curNode.nextSibling; break; } curNode = nodeStack.pop(); if (curNode === node) { break out; } } } }, /** * Reverts ... TODO */ revert: function () { // Reversion occurs backwards so as to avoid nodes subsequently // replaced during the matching phase (a forward process): for (var l = this.reverts.length; l--; ) { this.reverts[l](); } this.reverts = []; }, prepareReplacementString: function (string, portion, match) { var portionMode = this.options.portionMode; if (portionMode === PORTION_MODE_FIRST && portion.indexInMatch > 0) { return ""; } string = string.replace(/\$(\d+|&|`|')/g, function ($0, t) { var replacement; switch (t) { case "&": replacement = match[0]; break; case "`": replacement = match.input.substring(0, match.startIndex); break; case "'": replacement = match.input.substring(match.endIndex); break; default: replacement = match[+t] || ""; } return replacement; }); if (portionMode === PORTION_MODE_FIRST) { return string; } if (portion.isEnd) { return string.substring(portion.indexInMatch); } return string.substring( portion.indexInMatch, portion.indexInMatch + portion.text.length ); }, getPortionReplacementNode: function (portion, match) { var replacement = this.options.replace || ""; var wrapper = this.options.wrap; var wrapperClass = this.options.wrapClass; if (wrapper && wrapper.nodeType) { // Wrapper has been provided as a stencil-node for us to clone: var clone = doc.createElement("div"); clone.innerHTML = wrapper.outerHTML || new XMLSerializer().serializeToString(wrapper); wrapper = clone.firstChild; } if (typeof replacement == "function") { replacement = replacement(portion, match); if (replacement && replacement.nodeType) { return replacement; } return doc.createTextNode(String(replacement)); } var el = typeof wrapper == "string" ? doc.createElement(wrapper) : wrapper; if (el && wrapperClass) { el.className = wrapperClass; } replacement = doc.createTextNode( this.prepareReplacementString(replacement, portion, match) ); if (!replacement.data) { return replacement; } if (!el) { return replacement; } el.appendChild(replacement); return el; }, replaceMatch: function (match, startPortion, innerPortions, endPortion) { var matchStartNode = startPortion.node; var matchEndNode = endPortion.node; var precedingTextNode; var followingTextNode; if (matchStartNode === matchEndNode) { var node = matchStartNode; if (startPortion.indexInNode > 0) { // Add `before` text node (before the match) precedingTextNode = doc.createTextNode( node.data.substring(0, startPortion.indexInNode) ); node.parentNode.insertBefore(precedingTextNode, node); } // Create the replacement node: var newNode = this.getPortionReplacementNode(endPortion, match); node.parentNode.insertBefore(newNode, node); if (endPortion.endIndexInNode < node.length) { // ????? // Add `after` text node (after the match) followingTextNode = doc.createTextNode( node.data.substring(endPortion.endIndexInNode) ); node.parentNode.insertBefore(followingTextNode, node); } node.parentNode.removeChild(node); this.reverts.push(function () { if (precedingTextNode === newNode.previousSibling) { precedingTextNode.parentNode.removeChild(precedingTextNode); } if (followingTextNode === newNode.nextSibling) { followingTextNode.parentNode.removeChild(followingTextNode); } newNode.parentNode.replaceChild(node, newNode); }); return newNode; } else { // Replace matchStartNode -> [innerMatchNodes...] -> matchEndNode (in that order) precedingTextNode = doc.createTextNode( matchStartNode.data.substring(0, startPortion.indexInNode) ); followingTextNode = doc.createTextNode( matchEndNode.data.substring(endPortion.endIndexInNode) ); var firstNode = this.getPortionReplacementNode(startPortion, match); var innerNodes = []; for (var i = 0, l = innerPortions.length; i < l; ++i) { var portion = innerPortions[i]; var innerNode = this.getPortionReplacementNode(portion, match); portion.node.parentNode.replaceChild(innerNode, portion.node); this.reverts.push( (function (portion, innerNode) { return function () { innerNode.parentNode.replaceChild(portion.node, innerNode); }; })(portion, innerNode) ); innerNodes.push(innerNode); } var lastNode = this.getPortionReplacementNode(endPortion, match); matchStartNode.parentNode.insertBefore( precedingTextNode, matchStartNode ); matchStartNode.parentNode.insertBefore(firstNode, matchStartNode); matchStartNode.parentNode.removeChild(matchStartNode); matchEndNode.parentNode.insertBefore(lastNode, matchEndNode); matchEndNode.parentNode.insertBefore(followingTextNode, matchEndNode); matchEndNode.parentNode.removeChild(matchEndNode); this.reverts.push(function () { precedingTextNode.parentNode.removeChild(precedingTextNode); firstNode.parentNode.replaceChild(matchStartNode, firstNode); followingTextNode.parentNode.removeChild(followingTextNode); lastNode.parentNode.replaceChild(matchEndNode, lastNode); }); return lastNode; } }, }; return exposed; }); (function () { 'use strict'; /** * 脚本遵循AGPL License开源协议;在协议允许的范围类,可以自由修改 * 开完万岁!! */ //共有方法,全局共享 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, options={"active":true, "insert":true, "setParent":true}){ if (typeof GM_openInTab === "function") { GM_openInTab(url, options); } else { GM.openInTab(url, options); } }; 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(method, url, param, headers={"Content-Type": "application/json;charset=UTF-8"}){ return new Promise(function(resolve, reject){ GM_xmlhttpRequest({ url: url, method: method, data:param, headers:headers, 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.crossRequest=function(method, url, param){ if(!method){ method = "get"; } if(!url){ return new Promise(function(resolve, reject){ reject({"result":"error", "data":null}); }); } if(!param){ param = {}; } method = method.toUpperCase(); let config = { method: method }; if (method === 'POST') { config.headers['Content-Type'] = 'application/json'; config.body = JSON.stringify(param); } return new Promise(function(resolve, reject){ fetch(url, config).then(response => response.text()).then(text => { resolve({"result":"success", "data":text}); }).catch(error => { 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: 2147483648; 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.filterStr = function(str){ if(!str) return ""; str = str.replace(/\t/g,""); str = str.replace(/\r/g,""); return encodeURIComponent(str) }; this.getParamterQueryUrl = 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.getEndHtmlIdByUrl = function(url) { //获得以html结束的ID if(url.indexOf("?")!=-1){ url = url.split("?")[0] } if(url.indexOf("#")!=-1){ url = url.split("#")[0] } var splitText = url.split("/"); var idText = splitText[splitText.length-1]; idText = idText.replace(".html",""); return idText; }; this.suningParameter=function(url){ const regex = /product\.suning\.com\/(\d+\/\d+)\.html/; const match = url.match(regex); if(match){ return match[1].replace(/\//g, '-'); } return null; }; this.getEcommercePlatform=function(host = window.location.host){ let platform = ""; if(host.indexOf(".taobao.")!=-1 || host.indexOf(".liangxinyao.")!=-1){ platform = "taobao"; }else if(host.indexOf(".tmall.")!=-1){ platform = "tmall"; }else if(host.indexOf(".jd.")!=-1 || host.indexOf(".yiyaojd.")!=-1 || host.indexOf(".jkcsjd.")!=-1 || host.indexOf(".jingdonghealth.")!=-1){ platform = "jd"; }else if(host.indexOf(".vip.")!=-1 || host.indexOf(".vipglobal.")!=-1){ platform = "vpinhui"; }else if(host.indexOf(".suning.")!=-1){ platform = "suning"; } return platform; } 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; }; this.getSystemOS=function(){ var u = navigator.userAgent; if (!!u.match(/compatible/i) || u.match(/Windows/i)) { return 'windows'; } else if (!!u.match(/Macintosh/i) || u.match(/MacIntel/i)) { return 'macOS'; } else if (!!u.match(/iphone/i) || u.match(/Ipad/i)) { return 'ios'; } else if (!!u.match(/android/i)) { return 'android'; } else { return 'other'; } }; this.RPCDownloadFile = function(fileName, url, savePath="D:/", RPCURL="ws://localhost:16800/jsonrpc", RPCToken="") { const self = this; if(!savePath){ savePath = "D:/"; } if(!RPCURL){ RPCURL = "ws://localhost:16800/jsonrpc"; } let options = { //下载配置文件 "dir":savePath, "max-connection-per-server": "16", "header":["User-Agent:"+navigator.userAgent+"", "Cookie:"+document.cookie+"", "Referer:"+window.location.href+""] } if(!!fileName) { options.out = fileName; } let jsonRPC = { "jsonrpc": "2.0", "id": "huahuacat", "method": "aria2.addUri", "params": [[url], options], } if (!!RPCToken) { jsonRPC.params.unshift("token:" + RPCToken); // 必须要加在第一个 } return new Promise(function(resolve, reject) { var webSocket = new WebSocket(RPCURL); webSocket.onerror = function(event) { console.log("webSocket.onerror", event); reject("Aria2连接错误,请打开Aria2和检查RPC设置!"); } webSocket.onopen = function(){ webSocket.send(JSON.stringify(jsonRPC)); } webSocket.onmessage = function(event){ let result = JSON.parse(event.data); switch (result.method) { case "aria2.onDownloadStart": resolve("Aria2 开始下载【"+fileName+"】"); webSocket.close(); break; case "aria2.onDownloadComplete": break; default: break; } } }); }; this.getElementObject = function(selector, target=document.body, allowEmpty = true, delay=10, maxDelay=10 * 1000){ return new Promise((resolve,reject) =>{ if (selector.toUpperCase() === "BODY") { resolve(document.body); return; } if (selector.toUpperCase() === "HTML") { resolve(document.html); return; } let totalDelay = 0; let element = target.querySelector(selector); let result = allowEmpty ? !!element : (!!element && !!element.innerHTML); if(result){ resolve(element); } const elementInterval = setInterval(()=>{ if(totalDelay >= maxDelay){ clearInterval(elementInterval); resolve(null); } element = target.querySelector(selector); result = allowEmpty ? !!element : (!!element && !!element.innerHTML); if(result){ clearInterval(elementInterval); resolve(element); }else{ totalDelay += delay; } }, delay); }); }; /** * @param {Object} time * @param {Object} format * 时间格式化 * DateFormat(new Date(dateCreated), "yyyy-MM-dd hh:mm:ss") */ this.DateFormat = function(time, format) { var o = { "M+": time.getMonth() + 1, //月份 "d+": time.getDate(), //日 "h+": time.getHours(), //小时 "m+": time.getMinutes(), //分 "s+": time.getSeconds(), //秒 "q+": Math.floor((time.getMonth() + 3) / 3), //季度 "S": time.getMilliseconds() //毫秒 }; if(/(y+)/.test(format)){ format = format.replace(RegExp.$1, (time.getFullYear() + "").substr(4 - RegExp.$1.length)); } for(var k in o){ if(new RegExp("(" + k + ")").test(format)){ format = format.replace(RegExp.$1, (RegExp.$1.length == 1) ? (o[k]) : (("00" + o[k]).substr(("" + o[k]).length))); } } return format; }; this.decryptStr=function(str){ let result = atob(str); return result.split('').reverse().join(''); }; this.encryptStr=function(str){ let result = str.split('').reverse().join(''); return btoa(result); }; } //全局弹窗对象 const dialog = (function(){ class Dialog { constructor() { this.mask = document.createElement('div'); this.dialogStyle = document.createElement('style'); 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":"2147483647" }); this.content = document.createElement('div'); this.setStyle(this.content, { "max-width": '450px', "width":"100%", "max-height": '600px', "backgroundColor": '#fff', "boxShadow": '0 0 2px #999', "position": 'absolute', "left": '50%', "top": '50%', "transform": 'translate(-50%,-50%)', "borderRadius": '5px' }) 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; } document.body.appendChild(this.mask); this.title = document.createElement('div'); this.setStyle(this.title, { "width": '100%', "height": '40px', "lineHeight": '40px', "boxSizing": 'border-box', "background-color":"#dedede", "color": '#000', "text-align": 'center', "font-weight":"700", "font-size":"17px", "border-radius": "4px 4px 0px 0px" }); this.title.innerText = title; this.content.appendChild(this.title); this.closeBtn = document.createElement('div'); this.closeBtn.innerText = '×'; this.setStyle(this.closeBtn, { "textDecoration": 'none', "color": '#000', "position": 'absolute', "right": '10px', "top": '0px', "fontSize": '25px', "display":"inline-block", "cursor":"pointer" }) this.title.appendChild(this.closeBtn); const self = this; this.closeBtn.onclick = function(){ self.close(); if(param.onClose && (typeof param.onClose)==="function"){ param.onClose(); } } } showMake(param) { //添加公用样式表 if(param.hasOwnProperty("styleSheet")){ this.dialogStyle.textContent = param.styleSheet; } document.querySelector("head").appendChild(this.dialogStyle); 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); document.querySelector("head").removeChild(this.dialogStyle); } setStyle(ele, styleObj) { for(let attr in styleObj){ ele.style[attr] = styleObj[attr]; } } } let dialog = null; return (function() { if(!dialog) { dialog = new Dialog() } return dialog; })() })(); //全局统一方法对象 const commonFunctionObject = new CommonFunction(); commonFunctionObject.addCommonHtmlCss(); //统一html、css元素添加 let functionController = null; //相关功能关闭控制 functionController = commonFunctionObject.GMgetValue("setingData"); if(!functionController){ functionController={ "bilibiliHelper":true,"superVideoHelper":true, "abroadVideoHelper":true, "searchEnginesNavigation":true,"zhihuHelper":true, "shortVideoDownload":true } } //用户功能设置函数 function usersSeting(){ var bilibiliHelper=true, superVideoHelper=true, abroadVideoHelper=true, searchEnginesNavigation=true, zhihuHelper=true, shortVideoDownload=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("abroadVideoHelper")){ functionController.abroadVideoHelper = true; isUpdateStorage = true; }else{ abroadVideoHelper = functionController.abroadVideoHelper; } if(!functionController.hasOwnProperty("searchEnginesNavigation")){ functionController.searchEnginesNavigation = true; isUpdateStorage = true; }else{ searchEnginesNavigation = functionController.searchEnginesNavigation; } if(!functionController.hasOwnProperty("zhihuHelper")){ functionController.zhihuHelper = true; isUpdateStorage = true; }else{ zhihuHelper = functionController.zhihuHelper; } if(!functionController.hasOwnProperty("shortVideoDownload")){ functionController.shortVideoDownload = true; isUpdateStorage = true; }else{ shortVideoDownload = functionController.shortVideoDownload; } if(isUpdateStorage){ commonFunctionObject.GMsetValue("setingData",functionController); } var setingData=[ {"tag":"bilibiliHelper", "name":"B站使用加强(视频下载支持批量、浏览记录、一键三连)", "checked":bilibiliHelper}, {"tag":"zhihuHelper", "name":"知乎使用加强(内容标识、问答显示优化、视频下载等)", "checked":zhihuHelper}, {"tag":"superVideoHelper", "name":"全网VIP视频解析(支持爱奇艺、腾讯视频、B站番剧等)", "checked":superVideoHelper}, {"tag":"searchEnginesNavigation", "name":"搜索引擎使用加强(适配百度、360、搜狗、必应、Google等)", "checked":searchEnginesNavigation}, {"tag":"shortVideoDownload", "name":"短视频去水印下载(支持抖音、快手等)", "checked":shortVideoDownload}, {"tag":"abroadVideoHelper", "name":"国外视频解析下载(支持油管、Facebook等)", "checked":abroadVideoHelper} ] var content = ""; for(var i=0; i ` } dialog.showMake({ "title":"功能开关", "content":content, "onClose":function(){ location.reload(); }, "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":"#FF4D40"}); }); }) } }); } // 菜单按钮弹框 if(commonFunctionObject.isPC()){ GM_registerMenuCommand("功能开关",()=>usersSeting()); }else{ functionController.bilibiliHelper = false; functionController.abroadVideoHelper = false; functionController.searchEnginesNavigation = false; functionController.zhihuHelper = false; } //VIP视频解析接口可自定义;请严格按照格式添加 //showType=1(仅PC), showType=2(仅mobile), showType=3(同时显示) const originalInterfaceList = [ ]; function SuperVideoHelper(originalInterfaceList) { this.originalInterfaceList = originalInterfaceList; this.elementId = Math.ceil(Math.random() * 100000000) + "mmx"; 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", "bilibili.com", "baofeng.com", "pptv.com", "1905.com", "miguvideo.com", "sports.iqiyi.com" ]; let result = false; if (!host.startsWith("m.")) { //不是移动端执行 for (let i = 0; i < urls.length; i++) { if (window.location.host.includes("bilibili.com")) { if (window.location.href.includes("www.bilibili.com/bangumi/play")) { result = true; break; } } else { if (window.location.host.includes(urls[i])) { result = true; break; } } } } return result; }; this.showPlayerWindow = function(playObject) { //显示播放窗口 const url = playObject.url + window.location.href; commonFunctionObject.GMopenInTab(url); }; this.analysisCustomInterface = function() { //自定义接口解析 const customInterface = commonFunctionObject.GMgetValue(this.customInterfaceKey, ""); if (customInterface) { try { const customizeInterfaceList = []; const analysisArray = customInterface.split("\n"); for (let i = 0; i < analysisArray.length; i++) { const onePiece = analysisArray[i]; if (onePiece && onePiece.includes(",")) { const onePieceArray = onePiece.split(","); if (onePieceArray.length === 2 && onePieceArray[0] && /(http|https):\/\/\S*/.test(onePieceArray[1])) { customizeInterfaceList.push({ "name": "" + onePieceArray[0] + "", "url": "" + onePieceArray[1] + "", "showType": 1 }); } } } this.originalInterfaceList = customizeInterfaceList.concat(this.originalInterfaceList); } catch (e) {} } }; this.getQuicklyInterfaceIndex = function() { const quicklyInterfaceIndexString = commonFunctionObject.GMgetValue(this.quicklyInterfaceKey, "") + ""; let quicklyInterfaceIndex = this.defaultQuicklyInterfaceIndex; if (quicklyInterfaceIndexString) { quicklyInterfaceIndex = parseInt(quicklyInterfaceIndexString); } if (this.originalInterfaceList.length - 1 < quicklyInterfaceIndex) { quicklyInterfaceIndex = this.defaultQuicklyInterfaceIndex; } return quicklyInterfaceIndex; }; this.addHtmlElements = function() { //添加HTML const vipVideoImageBase64 = ""; const quicklyBase64 = ""; const currentHost = window.location.host; const quicklyInterfaceIndex = this.getQuicklyInterfaceIndex(); let currentQuicklyInterfaceObject = null; let category_1_html = ""; this.originalInterfaceList.forEach((item, index) => { if (item.showType !== 2) { let selected = ""; if (index === quicklyInterfaceIndex) { selected = "selected"; currentQuicklyInterfaceObject = item; } category_1_html += `${item.name}`; } }); let left = 0; let top = 120; const position = commonFunctionObject.GMgetValue("Position_" + currentHost); if (position) { left = position.left; top = position.top; } let color = "#FF4D40"; let hoverColor = "#000000"; if (currentHost.includes("bilibili.com")) { color = "#fb7299"; hoverColor = "#00B0E1"; } const 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; height:32px;line-height:32px;text-align:center;background-color:${color};} #vip_movie_box${this.elementId} .img_box${this.elementId}:hover{ background: linear-gradient(30deg, #2a66ff 40%, ${color}); } #vip_movie_box${this.elementId} .img_box${this.elementId}>img {width:20px; display:inline-block; vertical-align:middle;} #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;box-sizing:content-box!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); const htmlMould = `
接口添加
对现有接口不满意?可添加自定义接口哟~添加接口
${category_1_html}
免责声明:
1、需要使用VIP视频解析的,请自行添加接口,版权问题请联系相关解析接口所有者,脚本不承担相关责任!"
2、为创造良好的创作氛围,请大家支持正版!
3、脚本仅限个人学习交流,使用即已代表您已经充分了解相关问题,否则后果自负,特此声明!
`; document.body.insertAdjacentHTML('beforeend', htmlMould); }; this.runEvent = function() { //事件运行 const that = this; const vipMovieBox = document.getElementById(`vip_movie_box${this.elementId}`); const pluginInner = vipMovieBox.querySelector(`.plugin_inner_${this.elementId}`); const showhideBox = vipMovieBox.querySelector(`.showhide_box${this.elementId}`); const interfaceBox = vipMovieBox.querySelector(`.interface_box${this.elementId}`); const imgSetBtn = document.getElementById('img_set_6667897iio'); const imgQuicklyBtn = document.getElementById('img_quickly_6667897iio'); const quicklyImg = imgQuicklyBtn.querySelector('img'); pluginInner.addEventListener("mouseover", () => { showhideBox.style.display = 'block'; }); pluginInner.addEventListener("mouseout", () => { showhideBox.style.display = 'none'; }); interfaceBox.addEventListener("click", function(event) { if (event.target.tagName === 'SPAN') { const span = event.target; const index = parseInt(span.dataset.index); const playObject = that.originalInterfaceList[index]; that.showPlayerWindow(playObject); const allSpans = this.querySelectorAll('span'); allSpans.forEach(s => s.classList.remove("selected")); span.classList.add("selected"); commonFunctionObject.GMsetValue(that.quicklyInterfaceKey, index); quicklyImg.title = `快速开始(当前所选接口:${playObject.name})`; } }); imgSetBtn.addEventListener("click", () => { that.showSetingDialog(); }); imgQuicklyBtn.addEventListener("click", () => { const quicklyInterfaceIndex = that.getQuicklyInterfaceIndex(); const playObject = that.originalInterfaceList[quicklyInterfaceIndex]; that.showPlayerWindow(playObject); }); //右键移动位置 vipMovieBox.addEventListener('mousedown', function(e) { if (e.which === 3) { e.preventDefault(); vipMovieBox.style.cursor = "move"; const positionDiv = this.getBoundingClientRect(); const distenceX = e.pageX - positionDiv.left; const distenceY = e.pageY - positionDiv.top; const mouseMoveHandler = function(e) { let x = e.pageX - distenceX; let y = e.pageY - distenceY; const windowWidth = window.innerWidth; const windowHeight = window.innerHeight; if (x < 0) { x = 0; } else if (x > windowWidth - vipMovieBox.offsetWidth - 100) { x = windowWidth - vipMovieBox.offsetWidth - 100; } if (y < 0) { y = 0; } else if (y > windowHeight - vipMovieBox.offsetHeight) { y = windowHeight - vipMovieBox.offsetHeight; } vipMovieBox.style.left = `${x}px`; vipMovieBox.style.top = `${y}px`; commonFunctionObject.GMsetValue("Position_" + window.location.host, { "left": x, "top": y }); }; const mouseUpHandler = function() { document.removeEventListener('mousemove', mouseMoveHandler); document.removeEventListener('mouseup', mouseUpHandler); vipMovieBox.style.cursor = "pointer"; }; document.addEventListener('mousemove', mouseMoveHandler); document.addEventListener('mouseup', mouseUpHandler); document.addEventListener('contextmenu', 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.includes("www.iqiyi.com")) { this.removeVideoAdBlock_iqiyi(); } else if (currentHost.includes("v.qq.com")) { this.removeVideoAdBlock_vqq(); } else if (currentHost.includes("v.youku.com")) { this.removeVideoAdBlock_youku(); } else if (currentHost.includes("www.mgtv.com")) { this.removeVideoAdBlock_mgtv(); } else if (currentHost.includes("tv.sohu.com")) { this.removeVideoAdBlock_sohu(); } }; this.showSetingDialog = function() { const that = this; const customInterfaceKey = that.customInterfaceKey; const customInterface = commonFunctionObject.GMgetValue(customInterfaceKey, ""); const content = `
自定义解析接口
数据格式:[名字] + [,] + [接口地址]
例如:就是名字而已,https://xxxxxx?url=
注:一行一个
`; dialog.showMake({ "title": "解析接口添加", "content": content, "onContentReady": function($that) { const saveCustomInterfaceBtn = $that.dialogContent.querySelector(".save-custom-interface-btn"); saveCustomInterfaceBtn.addEventListener("click", function() { const customInterfaceTextarea = $that.dialogContent.querySelector(".custom-interface-textarea"); const content = customInterfaceTextarea.value; commonFunctionObject.GMsetValue(customInterfaceKey, content); commonFunctionObject.webToast({ "message": "自定义接口保存成功", "background": "#FF4D40" }); }); } }); }; this.start = function() { let delayTimeMs = 0; if (window.location.host.includes("www.bilibili.com")) { 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"]; let result = false; if (host.startsWith("m.")) { //是移动端执行 for (let i = 0; i < urls.length; i++) { if (host.includes(urls[i])) { result = true; break; } } } return result; }; this.getwindowElement = function() { let nodeObject = null; for (let i in this.playerNodes) { //获得窗口ID if (this.playerNodes[i].url === window.location.host) { nodeObject = this.playerNodes[i]; break; } } return nodeObject; }; this.getQuicklyInterfaceIndex = function() { const quicklyInterfaceIndexString = commonFunctionObject.GMgetValue(this.quicklyInterfaceKey, "") + ""; let quicklyInterfaceIndex = this.defaultQuicklyInterfaceIndex; if (quicklyInterfaceIndexString) { quicklyInterfaceIndex = parseInt(quicklyInterfaceIndexString); } if (this.originalInterfaceList.length - 1 < quicklyInterfaceIndex) { quicklyInterfaceIndex = this.defaultQuicklyInterfaceIndex; } return quicklyInterfaceIndex; }; this.addHtmlElements = function() { const nodeObject = this.getwindowElement(); const quicklyInterfaceIndex = this.getQuicklyInterfaceIndex(); if (!nodeObject) return; return new Promise((resolve, reject) => { const elementInterval = setInterval(() => { const nodeElementObject = document.querySelector(nodeObject.showNode); const themeColor = nodeObject.color; if (!nodeElementObject) return; clearInterval(elementInterval); let category_1_html = ""; this.originalInterfaceList.forEach((item, index) => { if (item.showType !== 1) { const selected = index === quicklyInterfaceIndex ? "selected" : ""; category_1_html += ``; } }); const htmlMould = `
选择解析接口
站外解析
免责申明:1、VIP视频解析中所用到的解析接口全部收集自互联网(源码可见),版权问题请联系相关解析接口所有者! 2、为创造良好的创作氛围,请大家支持正版! 3、脚本仅限个人学习交流,切勿用于任何商业等其它用途! 4、继续使用,即表明你已经明确使用脚本可能带来的风险,且愿意自行承担相关风险,对于风险脚本不承担任何责任!
`; nodeElementObject.insertAdjacentHTML('afterend', htmlMould); resolve("ok"); }, 100); }); }; this.getPlayObjectBySelect = function() { const selectElement = document.getElementById(`interface_selection_${this.elementId}`); const selectedOption = selectElement.options[selectElement.selectedIndex]; const indexString = selectedOption.getAttribute("index"); const index = indexString ? parseInt(indexString) : 0; return this.originalInterfaceList[index]; }; this.runEvent = function() { //事件运行 const self = this; const startAnalysisBtn = document.getElementById(`start_analysis_outer_${self.elementId}`); const interfaceSelection = document.getElementById(`interface_selection_${self.elementId}`); const playObject = self.getPlayObjectBySelect(); startAnalysisBtn.href = playObject.url + window.location.href; startAnalysisBtn.addEventListener('click', function(e) { if (commonFunctionObject.GMgetValue("copyright_video_remind_mobile_outer", null) === "true") { return; } const r = confirm( "脚本运行提醒!!!\u000d" + "使用站外解析功能,视频解析时脚本跳出本页面,如不同意此脚本行为,请点击【取消】按钮!!" ); if (r === false) { e.preventDefault(); } else { commonFunctionObject.GMsetValue("copyright_video_remind_mobile_outer", "true"); } }); interfaceSelection.addEventListener('change', function() { const selectedOption = this.options[this.selectedIndex]; const value = selectedOption.value; const index = parseInt(selectedOption.getAttribute("index")); startAnalysisBtn.href = value + window.location.href; commonFunctionObject.GMsetValue(self.quicklyInterfaceKey, index); }); }; this.start = function() { const self = this; if (this.isRun()) { this.addHtmlElements().then(() => { self.runEvent(); }); } }; } try { let newOriginalInterfaceList = originalInterfaceList; if (!functionController || functionController.superVideoHelper) { const superVideoHelperObject = new SuperVideoHelper(newOriginalInterfaceList); if (superVideoHelperObject.isRun()) { if (commonFunctionObject.GMgetValue("copyright_video_remind", null) === "true") { superVideoHelperObject.start(); } else { const 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); } /** * B站相关功能:视频多P下载,一键三联,浏览记录等 */ function BilibiliHelper() { this.isRun = function() { return window.location.host.indexOf("bilibili.com") !== -1; }; this.baseFunction = function() { /** * B站基本功能,一件三连、视频解析、视频下载 */ function baseFunctionObject() { this.elementId = Math.ceil(Math.random() * 100000000) + "mmx"; this.downloadSettingKey = "download_setting_key"; this.downloadResutError = function(btnElement) { btnElement.textContent = "下载视频"; btnElement.removeAttribute("disabled"); }; this.downloadResutSuccess = function(btnElement) { btnElement.textContent = "下载视频"; btnElement.removeAttribute("disabled"); }; this.getDownloadPages = function() { return new Promise(function(resolve, reject) { const pathname = window.location.pathname; let bv = null; if (pathname.indexOf("/medialist/play/watchlater/") !== -1) { bv = pathname.replace("/medialist/play/watchlater/", "").replace("/", ""); } else { bv = pathname.replace("/video/", "").replace("/", ""); } if (!bv) { resolve({ "status": "bv_null" }); return; } commonFunctionObject.request("get", "https://api.bilibili.com/x/web-interface/view?bvid=" + bv, null).then((resultData) => { const dataJson = JSON.parse(resultData.data); if (!dataJson || dataJson.code !== 0 || !dataJson.data) { resolve({ "status": "request_error" }); return; } const data = dataJson.data; if (!data) { resolve({ "status": "aid_null" }); return; } const aid = data.aid; const pic = data.pic; const title = data.title; if (!aid) { resolve({ "status": "aid_null" }); return; } commonFunctionObject.request("get", "https://api.bilibili.com/x/web-interface/view?aid=" + aid, null).then((resultData2) => { const dataJson2 = JSON.parse(resultData2.data); if (!dataJson2 || dataJson2.code !== 0 || !dataJson2.data) { resolve({ "status": "request_error" }); return; } const downloadData = dataJson2.data; const { aid, bvid } = downloadData; const items = []; if (downloadData.hasOwnProperty("ugc_season") && downloadData.ugc_season.hasOwnProperty("sections")) { const sections = downloadData.ugc_season.sections; let page = 1; for (let i = 0; i < sections.length; i++) { const section = sections[i]; if (section.hasOwnProperty("episodes")) { for (let j = 0; j < section.episodes.length; j++) { const episode = section.episodes[j]; items.push({ "cover": "", "page": page, "title": episode.title, "cid": episode.cid, "aid": episode.aid }); page++; } } } } else { for (let i = 0; i < downloadData.pages.length; i++) { const pageData = downloadData.pages[i]; items.push({ "cover": pageData.first_frame, "page": pageData.page, "title": pageData.part, "cid": pageData.cid, "aid": aid }); } } resolve({ "status": "success", "downloadData": { "items": items, "pic": pic, "title": title } }); }).catch((errorData) => { resolve({ "status": "request_error" }); }); }).catch((errorData) => { resolve({ "status": "request_error" }); }); }); }; this.startDownloadFile = function(options) { let aid = options.aid, cid = options.cid, fileName = options.fileName, savePath = options.savePath, RPCURL = options.RPCURL, RPCToken = options.RPCToken; let isByPRC = options.isByPRC; commonFunctionObject.request("get", "https://api.bilibili.com/x/player/playurl?avid=" + aid + "&cid=" + cid + "&qn=112", null).then((resultData3) => { if (!fileName) { fileName = (new Date()).getTime() + ""; } fileName = fileName.replace(/[\ |\~|\`|\=|\||\\|\;|\:|\"|\'|\,|\.|\>|\/]/g, ""); fileName = fileName.substring(0, 50); fileName = fileName + ".mp4"; const dataJson3 = JSON.parse(resultData3.data); if (!!dataJson3 && dataJson3.code === 0 && !!dataJson3.data) { const downloadUrl = dataJson3.data.durl[0].url; if (isByPRC) { commonFunctionObject.RPCDownloadFile(fileName, downloadUrl, savePath, RPCURL).then((data) => { commonFunctionObject.webToast({ "message": data, "time": 3000 }); }).catch((data) => { commonFunctionObject.webToast({ "message": data, "time": 3000 }); }); } else { window.open(downloadUrl); } } else { commonFunctionObject.webToast({ "message": "获取下载链接失败", "background": "#FF4D40" }); } }).catch((errorData) => { commonFunctionObject.webToast({ "message": "获取下载链接失败", "background": "#FF4D40" }); }); }; this.createModals = function() { const css = ` .modal-mask-${this.elementId}{ position:fixed; top:0; left:0; z-index:999; 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:600px; max-width:90%; max-height:80%; z-index:1000; left: 50%; transform: translateX(-50%); display:none; padding: 10px; overflow-y: auto; } .modal-body-${this.elementId} >.page-header{ height:30px; line-height:30px; position:relative; } .modal-body-${this.elementId} >.page-header >span{ display:inline-block; } .modal-body-${this.elementId} >.page-header >span:nth-child(1) { font-size:18px; font-weight:bold; position:absolute; left:10px; } .modal-body-${this.elementId} >.page-header >span:nth-child(2) { font-size:28px; font-weight:bold; position:absolute; right:10px; cursor:pointer; } .modal-body-${this.elementId} >.page-container{ max-height: 500px; overflow-y: auto; } .modal-body-${this.elementId} .page-wrap{ display: flex; flex-wrap: wrap; margin-top:5px; } .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} .page-wrap >.board-item >input{ width: 14px; height: 14px; vertical-align: middle; margin-right:5px; } .modal-body-${this.elementId} .page-wrap >.board-item >span{ vertical-align: middle; } .modal-body-${this.elementId} .modal-btn-wrap{ text-align: center; margin-top: 10px; cursor: pointer; } .modal-body-${this.elementId} .aria2-setting{ border:1px dashed #F1F1F1; border-radius:4px; margin-top:10px; } .modal-body-${this.elementId} .aria2-setting >.setting-item{ text-align: center; font-size:14px; margin:10px 0px; } .modal-body-${this.elementId} .aria2-setting >.setting-item .topic-name{ display:inline-block; width:80px; text-align:left; } .modal-body-${this.elementId} .aria2-setting >.setting-item> input{ width:300px; padding-left:10px; border:1px solid #888; outline:none; border-radius:3px; } .modal-body-${this.elementId} .modal-btn-wrap >span{ border:1px solid #ccc; display:inline-block; padding:3px 5px; margin:0px 5px; border-radius:3px; } .modal-body-${this.elementId} .tip-wrap{ margin-top: 10px; font-size:12px; } .modal-body-${this.elementId} .tip-wrap >.title{ font-size:16px; font-weight:bold; } .modal-body-${this.elementId} .tip-wrap >.content >ul >li{ margin-top:5px; } `; const html = ` `; commonFunctionObject.GMaddStyle(css); document.body.insertAdjacentHTML('beforeend', html); }; this.hideModals = function() { document.querySelector(`.modal-body-${this.elementId}`).style.display = 'none'; document.querySelector(`.modal-mask-${this.elementId}`).style.display = 'none'; }; this.showModals = function(pageHtml) { const self = this; const downloadSettingKey = self.downloadSettingKey; document.querySelector(`.modal-body-${self.elementId}`).style.display = 'block'; document.querySelector(`.modal-mask-${self.elementId}`).style.display = 'block'; document.querySelector(`.modal-body-${self.elementId} .page-wrap`).innerHTML = pageHtml; let savePath = "D:/"; if ("macOS" === commonFunctionObject.getSystemOS()) { savePath = ""; } const downloadSetting = commonFunctionObject.GMgetValue(this.downloadSettingKey, { "RPCURL": "ws://localhost:16800/jsonrpc", "savePath": savePath, "RPCToken": '', "downloadWay": "Motrix" }); const isMotrix = downloadSetting.downloadWay === "Motrix"; document.querySelector(`.modal-body-${self.elementId} input[name='RPCURL']`).value = downloadSetting.RPCURL; document.querySelector(`.modal-body-${self.elementId} input[name='savePath']`).value = downloadSetting.savePath; document.querySelector(`.modal-body-${self.elementId} input[name='RPCToken']`).value = downloadSetting.RPCToken; const downloadWayRadios = document.querySelectorAll(`.modal-body-${self.elementId} input[name='downloadWay']`); downloadWayRadios.forEach(radio => radio.removeAttribute('checked')); if (isMotrix) { document.querySelector(`.modal-body-${self.elementId} input[value='Motrix']`).setAttribute('checked', 'true'); } else { document.querySelector(`.modal-body-${self.elementId} input[value='AriaNgGUI']`).setAttribute('checked', 'true'); } const boardItems = document.querySelectorAll(`.modal-body-${self.elementId} .page-wrap >.board-item >span`); boardItems.forEach(item => { item.removeEventListener("click", self.handleDownloadClick); self.handleDownloadClick = function() { this.style.backgroundColor = "#ccc"; const downloadOptions = { "aid": this.dataset.aid, "cid": this.dataset.cid, "isByPRC": false }; self.startDownloadFile(downloadOptions); }; item.addEventListener("click", self.handleDownloadClick); }); document.querySelector(`.modal-body-${self.elementId} .page-header >span.close`).addEventListener("click", () => { self.hideModals(); }); document.querySelector(`.modal-body-${self.elementId} .modal-btn-wrap >span[name='selectall']`).addEventListener("click", () => { document.querySelectorAll(`.modal-body-${self.elementId} .page-wrap input[type='checkbox']`).forEach(checkbox => { checkbox.checked = true; }); }); document.querySelectorAll(`.modal-body-${self.elementId} input[name='downloadWay']`).forEach(radio => { radio.removeEventListener("change", self.handleDownloadWayChange); self.handleDownloadWayChange = function() { if (this.value === "Motrix") { document.querySelector(`.modal-body-${self.elementId} input[name='RPCURL']`).value = "ws://localhost:16800/jsonrpc"; } else { document.querySelector(`.modal-body-${self.elementId} input[name='RPCURL']`).value = "ws://localhost:6800/jsonrpc"; } }; radio.addEventListener("change", self.handleDownloadWayChange); }); document.querySelector(`.modal-body-${self.elementId} .modal-btn-wrap >span[name='removeSelect']`).addEventListener("click", () => { document.querySelectorAll(`.modal-body-${self.elementId} .page-wrap input[type='checkbox']`).forEach(checkbox => { checkbox.checked = false; }); }); document.querySelector(`.modal-body-${self.elementId} .modal-btn-wrap >span[name='downloadAll']`).addEventListener("click", () => { const RPCURL = document.querySelector(`.modal-body-${self.elementId} input[name='RPCURL']`).value; const savePath = document.querySelector(`.modal-body-${self.elementId} input[name='savePath']`).value; const RPCToken = document.querySelector(`.modal-body-${self.elementId} input[name='RPCToken']`).value; const downloadWay = document.querySelector(`.modal-body-${self.elementId} input[name='downloadWay']:checked`).value; commonFunctionObject.GMsetValue(downloadSettingKey, { "RPCURL": RPCURL, "savePath": savePath, "RPCToken": RPCToken, "downloadWay": downloadWay }); const inputElements = document.querySelectorAll(`.modal-body-${self.elementId} .page-wrap input[type='checkbox']:checked`); if (inputElements.length === 0) { commonFunctionObject.webToast({ "message": "至少需要选中1P", "background": "#FF4D40" }); return; } if (!savePath) { commonFunctionObject.webToast({ "message": "保存路径不能为空", "background": "#FF4D40" }); return; } if (!RPCURL) { commonFunctionObject.webToast({ "message": "PRC地址不能为空", "background": "#FF4D40" }); return; } const downloadOptions = { "aid": "", "cid": "", "isByPRC": true, "fileName": "", "savePath": savePath, "RPCURL": RPCURL, "RPCToken": RPCToken }; inputElements.forEach((element, index) => { setTimeout(() => { const aid = element.dataset.aid; const cid = element.dataset.cid; const fileName = element.getAttribute("title"); downloadOptions.aid = aid; downloadOptions.cid = cid; downloadOptions.fileName = fileName; self.startDownloadFile(downloadOptions); }, 1000 * index); }); }); }; this.createElementHtml = async function() { const existingElement = document.getElementById("bilibili_exti_9787fjfh12j"); if (existingElement) { existingElement.remove(); } const randomNumber = this.elementId; const self = this; const cssText = ` #bilibili_exti_9787fjfh12j{ position:fixed; left:-30px; top:250px; opacity:0.6; transition: 0.3s; } #bilibili_exti_9787fjfh12j >.self_s_btn{ background-color:#FB7299; color:#FFF; font-size:10px; border-radius:3px; cursor:pointer; margin:10px 0px; width:60px; height:20px; text-align:center; line-height:20px; } `; const htmlText = `
下载视频
一键三连
`; commonFunctionObject.GMaddStyle(cssText); document.body.insertAdjacentHTML('beforeend', htmlText); this.createModals(); const bilibiliExti = document.getElementById("bilibili_exti_9787fjfh12j"); bilibiliExti.addEventListener("mouseenter", function() { this.style.left = "0px"; this.style.opacity = 1; }); bilibiliExti.addEventListener("mouseleave", function() { this.style.left = (0 - this.offsetWidth) / 2 + "px"; this.style.opacity = 0.6; }); document.body.addEventListener("click", function(event) { if (event.target && event.target.id === `download_s_${randomNumber}`) { const btnElement = event.target; btnElement.setAttribute("disabled", "disabled"); btnElement.textContent = "准备中~"; self.getDownloadPages().then((resule) => { if (resule.status === "success") { const { items, pic, title } = resule.downloadData; let itemHtml = ""; itemHtml += `
标题:${title}(点我跳转封面)
`; for (let i = 0; i < items.length; i++) { const currentTitle = `【P${items[i].page}】${items[i].title}`; itemHtml += `
`; itemHtml += ``; itemHtml += `${currentTitle}`; itemHtml += `
`; } self.showModals(itemHtml); self.downloadResutSuccess(btnElement); } else { self.downloadResutError(btnElement); } }).catch((error) => { self.downloadResutError(btnElement); }); } if (event.target && event.target.id === `focus_s_${randomNumber}`) { document.querySelector("#arc_toolbar_report .video-like")?.click(); document.querySelector("#arc_toolbar_report .video-coin")?.click(); } }); }; this.start = function() { const locationHost = window.location.host; const locationPathname = window.location.pathname; if (locationHost === "www.bilibili.com" && (locationPathname.indexOf("/video") !== -1 || locationPathname.indexOf("/watchlater") !== -1)) { this.createElementHtml(); } }; } try { (new baseFunctionObject()).start(); } catch (e) { console.log("baseFunctionObject new error", e); } }; /** * 浏览历史记录提醒 */ this.recordViewFunction = function() { function recordViewObject() { this.localCacheName = "bilibili_video_record"; this.recordOneVideo = function() { return new Promise((resolve, reject) => { const bv = commonFunctionObject.getBilibiliBV(); let cacheText = commonFunctionObject.GMgetValue(this.localCacheName); cacheText = cacheText ? cacheText : ""; const maxLength = 12 * 500; const 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(element, top = 8, right = 8) { if (!element.querySelector("div[name='marklooked']")) { element.style.position = "relative"; const div = document.createElement("div"); div.setAttribute("name", "marklooked"); div.style.cssText = `z-index: 100;position:absolute; top:${top}px; right:${right}px; background-color: rgba(251,123,159,1); border-radius:3px; font-size:10px; color:#FFF;padding:0px 2px;`; div.textContent = "已看"; element.appendChild(div); } }; this.searchPageRemind = function() { const self = this; const elementArray = [ {"node": ".bili-video-card", "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() { const cacheText = commonFunctionObject.GMgetValue(self.localCacheName) || ""; elementArray.forEach(elementObj => { document.querySelectorAll(elementObj.node).forEach(element => { if (element.getAttribute("dealxll") !== "true") { const videoLink = element.querySelector("a[href^='//www.bilibili.com/video']"); if (videoLink) { const videourl = videoLink.getAttribute("href"); const bvs = videourl.match(/(\/BV(.*?)\/)/g); if (bvs && bvs.length === 1) { const bv = bvs[0].replace(/\//g, ""); if (cacheText.indexOf(bv) !== -1) { self.searchPageRemindHtml(element, elementObj.top, elementObj.right); } element.addEventListener("click", () => { self.searchPageRemindHtml(element, elementObj.top, elementObj.right); }); } element.setAttribute("dealxll", "true"); } } }); }); }, 500); }; this.start = function() { const self = 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; } }, 500); } if (window.location.host.indexOf("bilibili.com") !== -1) { this.searchPageRemind(); GM_registerMenuCommand("清空B站浏览记录", function() { if (confirm('是否要清空B站浏览记录?清空后将不可恢复...')) { commonFunctionObject.GMsetValue(self.localCacheName, ""); } }); } }; } try { (new recordViewObject()).start(); } catch (e) { console.log("recordViewObject new error", e); } }; /** * 视频描述文本转链接 */ this.textToLinkFunction = function() { function textToLinkObject() { this.link = function(selector) { const textToLinkArea = document.querySelector(selector); if (!textToLinkArea) { return; } findAndReplaceDOMText(textToLinkArea, { find: /(http|ftp|https):\/\/[\w\-_]+(\.[\w\-_]+)+([\w\-\.,@?^=%&:/~\+#]*[\w\-\@?^=%&/~\+#])?/g, replace: function(e, t) { const text = e.text; let element = null; if (text.indexOf("bilibili.com") === -1 && /^(http|ftp|https)/i.test(text)) { element = document.createElement("a"); element.setAttribute("href", text); element.setAttribute("target", "_blank"); element.style.color = "#00AEEC"; } else { element = document.createElement("span"); } element.innerText = text; return element; }, preset: "prose" }); }; this.start = function() { const selector = "#v_desc"; this.link(selector); const MutationObserver = window.MutationObserver || window.WebKitMutationObserver || window.MozMutationObserver; const bodyMutationObserver = new MutationObserver(() => { this.link(selector); }); const element = document.querySelector(selector); if (element) { bodyMutationObserver.observe(element, { "characterData": true, "attributes": true, "childList": true }); } }; } try { (new textToLinkObject()).start(); } catch (e) { console.log("textToLinkObject new error", e); } }; this.signIn = async function() {}; this.start = function() { if (this.isRun()) { this.baseFunction(); this.recordViewFunction(); this.textToLinkFunction(); this.signIn(); } }; } try { if (!functionController || functionController.bilibiliHelper) { new BilibiliHelper().start(); } } catch (e) { console.log("B站视频下载:error:" + e); } /** * 知乎助手开始 */ function ZhihuHelper() { this.markArticleOrQuestion = function() { const questionsCss = ` .AnswerItem .ContentItem-title a::before { content: '问题'; color: #f68b83; background-color: #f68b8333; font-weight: bold; font-size: 13px; padding: 1px 4px 0px; border-radius: 2px; display: inline-block; vertical-align: middle; margin: 0px 4px 0px 0px; } .ArticleItem .ContentItem-title a::before { content: '文章'; color: #0066FF; background-color: #E5EFFF; font-weight: bold; font-size: 13px; padding: 1px 4px 0; border-radius: 2px; display: inline-block; vertical-align: middle; margin: 0px 4px 0px 0px; } .ZvideoItem .ContentItem-title a::before { content:'视频'; color: #00BCD4; background-color: #00BCD433; font-weight: bold; font-size: 13px; padding: 1px 4px 0; border-radius: 2px; display: inline-block; vertical-align: middle; margin: 0px 4px 0px 0px; } .TopstoryItem--advertCard{ text-decoration:line-through; } `; commonFunctionObject.GMaddStyle(questionsCss); }; this.autoJumpTarget = function() { const regexResult = location.search.match(/target=(.+?)(&|$)/); if (regexResult && regexResult.length === 3) { location.href = decodeURIComponent(regexResult[1]); } }; // 为问题本身添加时间 this.addDateQuestion = function() { const title = document.querySelector(".QuestionPage"); if (title) { const dateCreatedEl = title.querySelector("[itemprop~=dateCreated][content]"); const dateModifiedEl = title.querySelector("[itemprop~=dateModified][content]"); if (!dateCreatedEl || !dateModifiedEl) return; const dateCreated = dateCreatedEl.content; const dateModified = dateModifiedEl.content; const createDate = commonFunctionObject.DateFormat(new Date(dateCreated), "yyyy-MM-dd hh:mm:ss"); const editDate = commonFunctionObject.DateFormat(new Date(dateModified), "yyyy-MM-dd hh:mm:ss"); const side = title.querySelector(".QuestionHeader-side"); const timeDiv = document.createElement('div'); timeDiv.innerHTML = `

创建于: ${createDate}

编辑于: ${editDate}

`; timeDiv.style.cssText = 'color:#6f6f6f;font-size:13px;'; side.appendChild(timeDiv); } }; // 为回答添加时间 this.addTimeAnswerItems = function() { const list = document.querySelectorAll(".AnswerItem:not(div[zh_date_mk='true'])"); let isComplete = true; for (let i = 0; i < list.length; i++) { const item = list[i]; if (item.getAttribute('zh_date_mk') === 'true') { continue; } item.setAttribute("zh_date_mk", "true"); try { const dateCreatedEl = item.querySelector("[itemprop~=dateCreated][content]"); const dateModifiedEl = item.querySelector("[itemprop~=dateModified][content]"); if (!dateCreatedEl || !dateModifiedEl) { isComplete = false; continue; } const dateCreated = dateCreatedEl.content; const dateModified = dateModifiedEl.content; const createDate = commonFunctionObject.DateFormat(new Date(dateCreated), "yyyy-MM-dd hh:mm:ss"); const editDate = commonFunctionObject.DateFormat(new Date(dateModified), "yyyy-MM-dd hh:mm:ss"); const sideItem = item.querySelector(".ContentItem-meta"); const timeDiv = document.createElement('div'); timeDiv.innerHTML = `创建于: ${createDate}   修改于: ${editDate}`; timeDiv.className = "Voters"; timeDiv.style.cssText = 'color:#6f6f6f;font-size:13px;display:block;padding:5px 0px;'; sideItem.appendChild(timeDiv); } catch (e) { console.error("Error adding date to answer item:", e); isComplete = false; } } return isComplete; }; // 提问者标识出来 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('.SpecialQuestionAuthor-Wrapper, .SpecialQuestionAuthor')) { return; } const jsData = document.querySelector('#js-initialData'); if (!jsData) return; const qJson = JSON.parse(jsData.textContent).initialState.entities.questions[/\d+/.exec(location.pathname)[0]].author; const html = `
${qJson.name}
`; const questionTopics = document.querySelector('.QuestionHeader-topics'); if (questionTopics) { questionTopics.insertAdjacentHTML('beforebegin', html); } }; this.startDealwithQuestion = function() { let isMarkComplete = true; setInterval(() => { if (isMarkComplete) { isMarkComplete = false; isMarkComplete = this.addTimeAnswerItems(); } }, 2500); this.showQuestionAuthor(); this.addDateQuestion(); }; this.downloadVideo = function() { let isMarkComplete = true; function addDownloadButton() { if (!isMarkComplete) return; isMarkComplete = false; const itemArray = document.querySelectorAll("._1tg8oir:not(span[zh_date_mk='true'])"); if (itemArray.length === 0) { isMarkComplete = true; return; } for (let i = 0; i < itemArray.length; i++) { const item = itemArray[i]; if (item.getAttribute('zh_date_mk') === 'true') { continue; } if (item.innerText.trim() !== "倍速") { continue; } const playButLi = item.parentNode.parentNode; if (!playButLi) continue; const downloadBut = playButLi.cloneNode(true); if (!downloadBut.querySelector('._1tg8oir')) continue; const downloadButChildren = Array.from(downloadBut.children); for (let j = 0; j < downloadButChildren.length; j++) { if (downloadButChildren[j].nodeName !== "BUTTON") { downloadBut.removeChild(downloadButChildren[j]); } } downloadBut.setAttribute("zh_date_mk", "true"); downloadBut.querySelector('._1tg8oir').innerText = '下载'; playButLi.before(downloadBut); downloadBut.addEventListener("click", function() { const href = window.location.href; let findClassName = ".ZVideoItem-video"; if (href.includes("www.zhihu.com/search")) { findClassName = ".List-item"; } else if (href.includes("www.zhihu.com/zvideo/")) { findClassName = ".ZVideo-player"; } else if (href.includes("https://video.zhihu.com/video")) { findClassName = "#player"; } if (!findClassName) return; const container = downloadBut.closest(findClassName); if (!container) return; const videoElement = container.querySelector("video"); if (videoElement && videoElement.src) { commonFunctionObject.GMopenInTab(videoElement.src); } }); } isMarkComplete = true; } setInterval(addDownloadButton, 1499); }; this.start = function() { const host = window.location.host; if (host === "link.zhihu.com") { this.autoJumpTarget(); } if (host.includes("zhihu.com")) { this.markArticleOrQuestion(); if (window.location.href.includes("www.zhihu.com/question/")) { this.startDealwithQuestion(); } this.downloadVideo(); } }; } try { if (!functionController || functionController.zhihuHelper) { (new ZhihuHelper()).start(); } } catch (e) { console.log("知乎助手:error:" + e); } /** * 搜索引擎资源提醒 */ function SearchEnginesNavigation() { this.customNavigationkey = "custom-navigation-key-8898"; this.serverNavigationkey = "server-navigation-key-8898"; 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": "www.bing.com", "element": "#b_context", "elementInput": "#sb_form_q" }, { "host": "www4.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": "textarea[name='q']" }, { "host": "www.google.com.hk", "element": "#rhs", "elementInput": "textarea[name='q']" }, { "host": "duckduckgo.com", "element": ".react-results--sidebar", "elementInput": "#search_form_input" }, ]; this.defaultNavigationData = [{ "name": "资源搜索", "list": [{ "name": "书签搜索 · 🔥发现", "url": "https://www.bookmarkearth.cn/?from=dxy" }, { "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://xueqiu.com/k?q=@@" }, { "name": "抖音搜索", "url": "https://www.douyin.com/search/@@" }, { "name": "搜狗|公众号", "url": "https://weixin.sogou.com/weixin?type=2&query=@@" }, { "name": "豆瓣搜索", "url": "https://www.douban.com/search?q=@@" }, { "name": "维基百科", "url": "https://en.wikipedia.org/w/index.php?search=@@" }, { "name": "法律法规", "url": "https://www.pkulaw.com/law/chl?Keywords=@@" }, { "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": "stackoverflow", "url": "https://stackoverflow.com/" }, { "name": "AI内容分析🔥", "url": "https://www.quzhuanpan.com/redirect/d_n?t=" + (new Date()).getTime() }, { "name": "在线工具", "url": "https://www.tool77.com/category/1?from=vbx" }, ] }, { "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=@@" }, { "name": "DuckDuckGo", "url": "https://duckduckgo.com/?t=h_&q=@@&ia=web" }, ] }, ]; this.getNavigationData = async function(element, elementInput) { const self = this; let navigationData = self.defaultNavigationData; let finalNavigationData = null; try { const customNavigationData = commonFunctionObject.GMgetValue(self.customNavigationkey, null); if (customNavigationData) { finalNavigationData = JSON.parse(JSON.stringify(customNavigationData)); } else { const currentMS = (new Date()).getTime(); const delayMS = 1000 * 60 * 5; const serverNavigationData = commonFunctionObject.GMgetValue(self.serverNavigationkey, null); if (!serverNavigationData || (currentMS - serverNavigationData.ms) > delayMS) { commonFunctionObject.request("get", `https://sct.staticj.top/script/api/nav?t=${currentMS}`, null).then(serverJson => { const data = JSON.parse(serverJson.data); data.ms = currentMS; commonFunctionObject.GMsetValue(self.serverNavigationkey, data); }).catch(error => {}); } if (serverNavigationData) { finalNavigationData = JSON.parse(serverNavigationData.list); } else { finalNavigationData = navigationData; } } } catch (e) { finalNavigationData = navigationData; } self.createHtml(element, elementInput, finalNavigationData); }; this.createCss = function(elementNum) { const innnerCss = ` #dsdsd99mmmjj7760011{ margin-bottom:20px; } .tab${elementNum}{ margin-bottom:8px; } .tab-c-titles${elementNum}{ margin-bottom:8px; } .tab-c-links${elementNum}{ } .tabs-t${elementNum}{ display: inline-block; width: 80px; height: 28px; line-height: 28px; font-size: 15px; letter-spacing: 0; text-align: center; font-weight: 400; border-radius: 6px; cursor: pointer; background: #f8f8f8; color: #333; } .tabs-t-selected-ddsds1idddx90{     color: #315EFB!important;;     font-weight: 500!important;;     background: rgba(49, 94, 251, 0.1)!important;; } .tabs-t-small-ddsds1idddx90{     margin-left: 8px; } .tab-c-links${elementNum} a[name='navigation']{ display:inline-block; text-align:center; margin-right:12px; margin-top:5px; overflow: hidden; white-space: nowrap; text-overflow:ellipsis; box-sizing:border-box; line-height:20px; font-size:14px!important; text-decoration: none; color:#1a0dab; } .tab-c-links${elementNum} a[name='navigation']:hover{ text-decoration: underline; } .bookmarks${elementNum}{ min-height:50px; } `.trim().replace(/\s+/g, " "); if (!document.getElementById("plugin_css_style_dddsoo")) { const style = document.createElement("style"); style.id = "plugin_css_style_dddsoo"; style.textContent = innnerCss; document.head.appendChild(style); } }; this.showSetingDialog = function() { const self = this; let customNavigationData = ""; const customNavigation = commonFunctionObject.GMgetValue(self.customNavigationkey, null); if (customNavigation) { customNavigationData = JSON.stringify(customNavigation, null, 4); } const content = `
注意事项如下:
1、请严格按照格式添加,否则不生效
2、数据为json格式,请确保json格式正确,必要时请到https://www.json.cn/校验
3、点击下面”示例“按钮,查看具体格式情况
4、链接中的搜索关键词请用”@@“代替,脚本会自动替换成当前搜索词。例如:https://www.baidu.com/s?wd=@@
5、大家可以自定义导航数据,但是必须要注意数据格式,发现出现错误,可点“初始化”
${customNavigationData}
`; dialog.showMake({ "title": "自定义添加导航", "content": content, "onClose": function() { location.reload(); }, "onContentReady": function($that) { const navigationExample = $that.dialogContent.querySelector(".navigation-example"); const navigationClear = $that.dialogContent.querySelector(".navigation-clear"); const navigationSave = $that.dialogContent.querySelector(".navigation-save"); const navigationInit = $that.dialogContent.querySelector(".navigation-init"); const textarea = $that.dialogContent.querySelector(".navigation-textarea"); navigationExample.addEventListener("click", () => { textarea.value = JSON.stringify(self.defaultNavigationData, null, 4); }); navigationClear.addEventListener("click", () => { textarea.value = ""; }); navigationInit.addEventListener("click", () => { textarea.value = ""; commonFunctionObject.GMsetValue(self.customNavigationkey, null); }); navigationSave.addEventListener("click", () => { const content = textarea.value; if (!content) { commonFunctionObject.GMsetValue(self.customNavigationkey, null); commonFunctionObject.webToast({ "message": "保存成功:数据为空", "background": "#FF4D40" }); return; } if (content.length === 0 || content.indexOf("{") === -1 || content.indexOf("[") === -1) { commonFunctionObject.webToast({ "message": "格式错误,请更正", "background": "#FF4D40" }); return; } try { const contentJson = JSON.parse(content); if (Array.isArray(contentJson)) { let isOK = true; for (let i = 0; i < contentJson.length; i++) { if (Array.isArray(contentJson[i])) { isOK = false; break; } if (!contentJson[i].hasOwnProperty("name") || !contentJson[i].hasOwnProperty("list")) { isOK = false; break; } if (typeof(contentJson[i]["name"]) !== "string") { isOK = false; break; } if (!Array.isArray(contentJson[i]["list"])) { isOK = false; break; } for (let j = 0; j < contentJson[i]["list"].length; j++) { if (!contentJson[i]["list"][j].hasOwnProperty("name") || !contentJson[i]["list"][j].hasOwnProperty("url")) { isOK = false; break; } if (typeof(contentJson[i]["list"][j]["name"]) !== "string" || typeof(contentJson[i]["list"][j]["url"]) !== "string") { isOK = false; break; } } if (!isOK) { break; } } if (isOK) { commonFunctionObject.GMsetValue(self.customNavigationkey, contentJson); commonFunctionObject.webToast({ "message": "保存成功", "background": "#FF4D40" }); } else { commonFunctionObject.webToast({ "message": "格式错误,请更正", "background": "#FF4D40" }); } } else { commonFunctionObject.webToast({ "message": "格式错误,请更正", "background": "#FF4D40" }); } } catch (e) { commonFunctionObject.webToast({ "message": "格式错误,请更正", "background": "#FF4D40" }); } }); } }); }; this.createHtml = function(element, elementInput, navigationData) { const existingElement = document.getElementById("dsdsd99mmmjj7760011"); if (existingElement) { existingElement.remove(); } let isComplate = true; const self = this; const elementNum = commonFunctionObject.randomNumber(); const elementInterval = setInterval(() => { if (isComplate) { const elementToPrepend = document.querySelector(element); const box = document.getElementById("dsdsd99mmmjj7760011"); isComplate = false; if (elementToPrepend && !box) { const nameArray = []; const linkArray = []; for (let i = 0; i < navigationData.length; i++) { let name = ""; if (i === 0) { name += `${navigationData[i].name}`; } else { name += `${navigationData[i].name}`; } nameArray.push(name); let links = ""; if (i === 0) { links = `
`; } else { links = `"; linkArray.push(links); } const html = `
${nameArray.join("")}
${linkArray.join("")}
*该数据由油猴脚本提供    🔧自定义网址
`; self.createCss(elementNum); elementToPrepend.insertAdjacentHTML('afterbegin', html); document.querySelectorAll(`#dsdsd99mmmjj7760011 .tabs-t${elementNum}`).forEach(tab => { tab.addEventListener("click", function() { document.querySelectorAll("div[id^='tab-list-xxsddddssd-']").forEach(div => div.style.display = 'none'); document.querySelectorAll(`.tabs-t${elementNum}`).forEach(span => span.classList.remove("tabs-t-selected-ddsds1idddx90")); document.getElementById(this.getAttribute("name")).style.display = 'block'; this.classList.add("tabs-t-selected-ddsds1idddx90"); }); }); document.querySelectorAll("#dsdsd99mmmjj7760011 a[name='navigation']").forEach(link => { link.addEventListener("click", function(e) { const url = this.dataset.url; const inputValue = document.querySelector(elementInput).value; commonFunctionObject.GMopenInTab(url.replace("@@", inputValue)); e.preventDefault(); }); }); document.querySelector("#dsdsd99mmmjj7760011 a[name='customNavigation']").addEventListener("click", function(e) { self.showSetingDialog(); e.preventDefault(); }); } isComplate = true; } }, 100); }; this.hookBaidu = function() { const items = document.querySelectorAll("#content_left>div"); for (let item of items) { if (item.getAttribute("baidu_dealxx")) { continue; } item.setAttribute("baidu_dealxx", "--"); const a = item.querySelector("a"); if (!a || !a.href) { continue; } const OP_LOG_LINK = item.querySelector(".OP_LOG_LINK"); if (OP_LOG_LINK && OP_LOG_LINK.innerText.search("http") !== -1) { continue; } const cGapBottomSmall = item.querySelector(".c-gap-bottom-small"); if (cGapBottomSmall) { continue; } if (a.href.includes("www.baidu.com/link?url=")) { const url = item.getAttribute("mu"); if (url && url.indexOf("http") !== -1 && !url.includes("nourl.ubs.baidu.com")) { a.href = url; item.insertAdjacentHTML('beforeend', `
${url}
`); } } const itemNews = item.querySelectorAll("[class^=single-card-wrapper] div, [class^=group-wrapper] div"); if (!itemNews) { continue; } for (let itemNew of itemNews) { let dataUrl = null; const divs = itemNew.querySelectorAll("div"); for (let div of divs) { dataUrl = div.getAttribute("data-url"); if (dataUrl) { const innerA = itemNew.querySelector("a"); if (innerA) { innerA.setAttribute("href", dataUrl); } } } } } }; this.hookGoogle = function() { const items = document.querySelectorAll("#center_col a"); for (let a of items) { if (!a.getAttribute("target")) { a.setAttribute("target", "_blank"); } } }; this.hooks = function() { const host = window.location.host; const self = this; setInterval(() => { if (host === "www.baidu.com") { self.hookBaidu(); } else if (host === "www.google.com" || host === "www.google.com.hk") { self.hookGoogle(); } }, 300); }; this.show = function() { const self = this; const host = window.location.host; const href = window.location.href; const matches = self.searchEnginesData.some(engine => host === engine.host && href.includes(engine.host)); if (matches) { let currentSearchEnginesData = null; for (let i = 0; i < self.searchEnginesData.length; i++) { if (host === self.searchEnginesData[i].host) { currentSearchEnginesData = self.searchEnginesData[i]; break; } } if (currentSearchEnginesData) { self.getNavigationData(currentSearchEnginesData.element, currentSearchEnginesData.elementInput); } self.hooks(); } }; this.start = function() { this.show(); }; } try { if (!functionController || functionController.searchEnginesNavigation) { (new SearchEnginesNavigation()).start(); } } catch (e) { console.log("搜索引擎导航:error:" + e); } /** * 购物助手部分功能借鉴自:https://greasyfork.org/zh-CN/scripts/428266 * 作者:洪皓儿,原脚本开源协议:AGPL License * 本脚本继承AGPL License协议并开源,在源代码基础上优化了部分逻辑,修复了部分bug,特此申明!! */ const recordBrowsingHistoryKey = "record_browsing_history_mark_key"; const browsedHtml = `
已浏览
`; function QueryCoupon() { this.platforms = ["detail.tmall.com", "item.taobao.com", "item.jd.com", "item.yiyaojd.com", "npcitem.jd.hk", "detail.tmall.hk", "detail.vip.com", "item.jkcsjd.com", "product.suning.com","item.jingdonghealth.cn" ]; this.createQrcodeIsResult = true; this.isRun = function() { for (let i = 0; i < this.platforms.length; i++) { if (window.location.host.indexOf(this.platforms[i]) !== -1) { return true; } } return false; }; this.filterName = function(str) { if (!str) return ""; str = str.replace(/\t/g, "").replace(/\r/g, ""); return encodeURIComponent(str); }; this.getGoodsData = async function(platform) { let goodsId = ""; let goodsName = ""; const href = window.location.href; if (platform === "taobao" || platform === "tmall") { goodsId = commonFunctionObject.getParamterQueryUrl(window.location.search, "id"); try { const titleObj = document.querySelector("[class^='ItemTitle--']"); if (titleObj) { goodsName = titleObj.textContent; } } catch (e) {} } else if (platform === "jd") { goodsId = commonFunctionObject.getEndHtmlIdByUrl(href); try { const titleObj = document.querySelector(".sku-name"); if (titleObj) { goodsName = titleObj.textContent; } } catch (e) {} } else if (platform === "vpinhui") { goodsId = commonFunctionObject.getEndHtmlIdByUrl(href).replace("detail-", ""); const titleObj = document.querySelector(".pib-title-detail"); if (titleObj) { goodsName = titleObj.textContent; } } else if (platform === "suning") { goodsId = commonFunctionObject.suningParameter(href); const titleObj = document.querySelector("#itemDisplayName"); if (titleObj) { goodsName = titleObj.textContent; } } const data = { "goodsId": goodsId, "goodsName": this.filterName(goodsName) }; return data; }; this.randomSpmValue = function() { document.querySelectorAll("meta[name='data-spm'], meta[name='spm-id']").forEach(meta => { const max = 5000; const min = 1000; const randomValue = Math.floor(Math.random() * (max - min + 1)) + min; const randomLetter = String.fromCharCode(Math.floor(Math.random() * 26) + "a".charCodeAt(0)); meta.setAttribute("content", randomValue + randomLetter); }); document.body.querySelectorAll("*").forEach(element => { element.removeAttribute("data-spm-anchor-id"); element.removeAttribute("data-spm"); }); }; this.runAliDeceptionSpm = function() { const host = window.location.host; if (host.indexOf("aliyun.com") !== -1 || host.indexOf("taobao.com") !== -1 || host.indexOf("tmall.com") !== -1) { this.randomSpmValue(); setInterval(() => { this.randomSpmValue(); }, 2000); } }; this.browsingHistoryMark = function(platform, goodsId) { let histories = commonFunctionObject.GMgetValue(recordBrowsingHistoryKey, []); const saveContent = platform + "_" + goodsId; if (!histories.includes(saveContent)) { histories.unshift(saveContent); commonFunctionObject.GMsetValue(recordBrowsingHistoryKey, histories.slice(0, 60)); } }; this.createHtml = async function(platform, goodsId, goodsName) { if (!platform || !goodsId) { return "kong"; } this.browsingHistoryMark(platform, goodsId); let addition = ""; if (platform === "vpinhui") { const vip = goodsId.split("-"); addition = vip[0]; goodsId = vip[1]; } const goodsCouponUrl = "https://j.jiayoushichang.com/api/ebusiness/find?n=7&v=1.0.2&p="+platform+"&i="+goodsId+"&q="+goodsName+"&addition="+addition; try { const data = await commonFunctionObject.request("GET", goodsCouponUrl, null); if (data.result === "success" && data.data) { const json = JSON.parse(data.data); await this.createCoupon(platform, json.data); await this.createQrcode(platform, json.mscan); let heartms = 0; const HEART_DELAY = 1500, MAX_MS = 1000 * 30; const createResultInterval = setInterval(async () => { if (this.createQrcodeIsResult) { if (document.querySelector("*[name='exist-llkbccxs-9246-hi']") || heartms >= MAX_MS) { clearInterval(createResultInterval); } else { await this.createCoupon(platform, json.data); } } heartms += HEART_DELAY; }, HEART_DELAY); } } catch (e) { console.log("createCouponHtml:", e); } }; this.getHandlerElement = async function(handler) { const getElement = async (handler) => { const promiseArray = []; const handlers = handler.split("@"); for (let i = 0; i < handlers.length; i++) { const eleName = handlers[i]; if (!eleName) continue; if (eleName === "body") { promiseArray.push(new Promise(resolve => resolve(document.body))); } else if (eleName === "html") { promiseArray.push(new Promise(resolve => resolve(document.documentElement))); } else { promiseArray.push(commonFunctionObject.getElementObject(eleName, document.body, true, 10, 1500)); } } const element = await Promise.race(promiseArray); return element || null; }; const element = await getElement(handler); return new Promise(resolve => resolve(element)); }; this.createCoupon = async function(platform, result) { try { this.createQrcodeIsResult = false; if (!result || result === "null" || !result.hasOwnProperty("css") || !result.hasOwnProperty("html") || !result.hasOwnProperty("handler")) { return; } const { css: cssText, html: htmlText, handler, templateId } = result; if (!cssText || !htmlText || !handler) { return; } GM_addStyle(cssText); const handlerElement = await this.getHandlerElement(handler); if (handlerElement) { if (platform === "taobao" || platform === "tmall") { handlerElement.parentNode.insertAdjacentHTML('afterend', htmlText); } else if (platform === "jd" || platform === "vpinhui" || platform === "suning") { handlerElement.insertAdjacentHTML('afterend', htmlText); } } const template = document.getElementById(templateId); if (!template) { return; } const couponId = template.dataset.id; const goodsPrivateUrl = "https://j.jiayoushichang.com/api/private/change/coupon?script=7&platform="+platform+"&id="; if (!/\d/.test(couponId)) { return; } setInterval(() => { template.querySelectorAll("*").forEach(el => el.removeAttribute("data-spm-anchor-id")); }, 400); const couponElementA = template.querySelector("a[name='cpShUrl']"); if (couponElementA) { couponElementA.addEventListener("click", event => { event.stopPropagation(); event.preventDefault(); commonFunctionObject.request("GET", goodsPrivateUrl + couponId, null).then(privateResultData => { if (privateResultData.result === "success" && privateResultData.data) { const url = JSON.parse(privateResultData.data).url; if (url) GM_openInTab(url, { active: true }); } }); }); } const canvasElement = document.getElementById(`ca${templateId}`); if (!canvasElement) { return; } const qrcodeResultData = await commonFunctionObject.request("GET", goodsPrivateUrl + couponId, null); if (qrcodeResultData && qrcodeResultData.result === "success" && qrcodeResultData.data) { const img = JSON.parse(qrcodeResultData.data).img; if (img) { const cxt = canvasElement.getContext("2d"); const imgData = new Image(); imgData.src = img; imgData.onload = function() { cxt.drawImage(imgData, 0, 0, imgData.width, imgData.height); }; } } } catch (e) { console.log("~~~~~~~~~~~~~~~~~", e); } finally { this.createQrcodeIsResult = true; } }; this.createQrcode = async function(platform, mscan) { if (!mscan || mscan === "null" || !mscan.hasOwnProperty("mount") || !mscan.hasOwnProperty("html") || !mscan.hasOwnProperty("qrcode")) { return; } const { mount, html, qrcode, iden } = mscan; if (mount && html && qrcode && iden) { const mountElement = document.querySelector(mount); if (mountElement) { mountElement.insertAdjacentHTML('beforeend', html); const canvasElement = document.getElementById(`mscan${iden}`); if (canvasElement) { const width = canvasElement.getAttribute("width"); const height = canvasElement.getAttribute("height"); const cxt = canvasElement.getContext("2d"); const imgData = new Image(); imgData.src = qrcode; imgData.onload = function() { cxt.drawImage(imgData, 0, 0, width, height); }; } } } }; this.start = async function() { if (this.isRun()) { this.runAliDeceptionSpm(); const platform = commonFunctionObject.getEcommercePlatform(); if (!platform) return; if (platform === "tmall" || platform === "taobao") { commonFunctionObject.getElementObject("div[class^='skuWrapper--']", document.body, false, 10, 1500).then(skuItemWrapper => { if (skuItemWrapper) { skuItemWrapper.style.maxHeight = "400px"; skuItemWrapper.style.overflow = "auto"; } }).catch(() => {}); } else if (platform === "jd") { const skuItemWrapper = document.querySelector("#choose-attrs"); if (skuItemWrapper) { skuItemWrapper.style.maxHeight = "400px"; skuItemWrapper.style.overflow = "auto"; } } const goodsData = await this.getGoodsData(platform); this.createHtml(platform, goodsData.goodsId, goodsData.goodsName); } }; } function SearchPageObject() { this.intervalIsRunComplete = true; this.histories = commonFunctionObject.GMgetValue(recordBrowsingHistoryKey, []); this.isRun = function() { const visitHref = window.location.href; const allows = [ /^https:\/\/www\.taobao\.com(\/|\/\?)?/i, /^https:\/\/s\.taobao\.com/i, /^https:\/\/shop(\d+)\.taobao\.com/i, /^https:\/\/www\.tmall\.com(\/|\/\?)?/i, /pages\.tmall\.com/i, /list\.tmall\.com/i, /list\.tmall\.hk/i, /tmall\.com\/category/i, /tmall\.com\/search/i, /tmall\.com\/shop/i, /tmall\.com\/\?q=/i, /maiyao\.liangxinyao\.com/i, /^https:\/\/www\.jd\.com(\/|\/\?)?/i, /search\.jd\.com/i, /search\.jd\.hk/i, /pro\.jd\.com\/mall/i, /jd\.com\/view_search/i, /category\.vip\.com/i, /list\.vip\.com/i, /^https:\/\/(?!product|dfp\.)([^\/]+)\.suning\.com\//i ]; return allows.some(reg => reg.test(visitHref)); }; this.requestConf = function() { return new Promise((resolve, reject) => { commonFunctionObject.crossRequest("GET", "https://j.jiayoushichang.com/api/plugin/load/conf", null).then(data => { if (data.result === "success" && data.data) { resolve(data.data); } else { resolve(null); } }); }); }; this.pickupSearchElements = function(conf, platform) { const selectorElementList = []; const visitHref = window.location.href; let confFilter = conf; try { confFilter = confFilter.replace(/\\\\/g, "\\"); } catch (e) {} const confJson = JSON.parse(confFilter); if (confJson.hasOwnProperty(platform)) { const platformConfJson = confJson[platform]; for (let i = 0; i < platformConfJson.length; i++) { const itemJson = platformConfJson[i]; if (!itemJson.hasOwnProperty("elements") || !itemJson.hasOwnProperty("matches")) { continue; } const { elements, matches } = itemJson; const isMatch = matches.map(reg => (new RegExp(reg, "i")).test(visitHref)).some(res => res); if (isMatch) { for (let j = 0; j < elements.length; j++) { selectorElementList.push({ "element": elements[j]["element"], "findA": elements[j]["findA"], "page": elements[j]["page"], "extra": elements[j]["extra"] }); } } } } return selectorElementList; }; this.createAllElementHtml = function(items) { this.intervalIsRunComplete = false; this.processLinksInBatches(items, 18).then(() => { this.intervalIsRunComplete = true; }); }; this.processLinksInBatches = async function(items, batchSize) { const results = []; for (let i = 0; i < items.length; i += batchSize) { const batch = items.slice(i, i + batchSize); const batchResults = await Promise.all( batch.map(item => this.createOneElementHtml(item)) ); results.push(...batchResults); } return results; }; this.getAnchorElement = function(element, findA) { let finalElement = null; if (findA === "this") { finalElement = element; } else { finalElement = element.querySelector(findA.replace(/^child@/, "")); } return finalElement; }; this.createOneElementHtml = function(item) { const { element, page, findA, extra } = item; const self = this; return new Promise(function(resolve) { if (element.getAttribute("honghaoerbox")) { resolve(-10000); return; } element.setAttribute("honghaoerbox", "true"); element.style.position = "relative"; element.addEventListener("click", function() { this.insertAdjacentHTML('beforeend', browsedHtml); }); const finalElement = self.getAnchorElement(element, findA); if (!finalElement) { resolve(-30000); return; } let goodsDetailUrl = null; let isAnchorA = true; if (extra) { const { durl, attribute } = extra; const attributeValue = finalElement.getAttribute(attribute); if (attributeValue) { goodsDetailUrl = durl.replace("@", attributeValue); isAnchorA = false; } } else { goodsDetailUrl = finalElement.getAttribute("href"); } if (!goodsDetailUrl) { resolve(-20000); return; } let analysisData = null; if (page.indexOf("jd_") !== -1) { const jdId = commonFunctionObject.getEndHtmlIdByUrl(goodsDetailUrl); if (jdId) analysisData = { "id": jdId, "platform": "jd" }; } else if (page.indexOf("vpinhui_") !== -1) { const vipId = commonFunctionObject.getEndHtmlIdByUrl(goodsDetailUrl).replace("detail-", ""); if (vipId) { analysisData = { "id": vipId.split("-")[1], "platform": "vpinhui" }; } } else if (page.indexOf("suning_") !== -1) { const suningId = commonFunctionObject.suningParameter(goodsDetailUrl); if (suningId) { analysisData = { "id": suningId, "platform": "suning" }; } } else { const platform = commonFunctionObject.getEcommercePlatform(goodsDetailUrl); const id = commonFunctionObject.getParamterQueryUrl(goodsDetailUrl, "id"); if (platform && id) { analysisData = { "id": id, "platform": platform }; } } if (!analysisData) { resolve(-30000); return; } const mark = analysisData.platform + "_" + analysisData.id; if (self.histories.includes(mark)) { element.insertAdjacentHTML('beforeend', browsedHtml); } const searchUrl = "https://j.jiayoushichang.com/api/ebusiness/coupon/exist/"+analysisData.platform+"?no=7&id="+analysisData.id; commonFunctionObject.crossRequest("GET", searchUrl, null).then(data => { if (data.result === "success" && data.data) { const { id, tip, encryptLink } = JSON.parse(data.data); if (tip) { element.insertAdjacentHTML('beforeend', tip); } if (encryptLink) { let decryptUrl = null; try { const decryptLink = atob(encryptLink); decryptUrl = decryptLink.split('').reverse().join(''); } catch (e) {} if (decryptUrl) { if (isAnchorA) { self.relativeAnchorAJu(page, element, decryptUrl); } else { self.relativeJu(element, decryptUrl); } } } } resolve(10000); }).catch(() => { resolve(-40000); }); }); }; this.relativeJu = function(element, decryptUrl) { element.addEventListener("click", function(e) { e.preventDefault(); e.stopPropagation(); commonFunctionObject.GMopenInTab(decryptUrl); }, true); }; this.relativeAnchorAJu = function(page, element, decryptUrl) { const self = this; try { if (page.indexOf("jd_") !== -1) { element.querySelectorAll("a").forEach(a => { const href = a.getAttribute("href"); if (/item\.jd|npcitem\.jd/.test(href)) { a.removeAttribute("onclick"); a.addEventListener("click", function(e) { e.preventDefault(); e.stopPropagation(); commonFunctionObject.GMopenInTab(decryptUrl); }, true); } }); } else if (page.indexOf("taobao_") !== -1 || page.indexOf("tmall_") !== -1) { element.addEventListener("click", function(e) { const target = e.target; const tagName = target.tagName.toUpperCase(); let isPreventDefault = false; if (tagName === "A") { const href = target.getAttribute("href"); const isDetail = [/detail\.tmall\.com/, /item\.taobao\.com/] .some(reg => reg.test(href)); if (isDetail) { isPreventDefault = true; } } else { isPreventDefault = true; } if (isPreventDefault) { e.preventDefault(); e.stopPropagation(); commonFunctionObject.GMopenInTab(decryptUrl); } }, true); } else if (page.indexOf("vpinhui_") !== -1) { element.querySelectorAll("a").forEach(a => { const href = a.getAttribute("href"); if (href && href.indexOf("detail.vip.com/detail-") !== -1) { a.addEventListener("click", function(e) { e.preventDefault(); e.stopPropagation(); commonFunctionObject.GMopenInTab(decryptUrl); }, true); } }); } else if (page.indexOf("suning_") !== -1) { element.querySelectorAll("a").forEach(a => { const href = a.getAttribute("href"); if (href && href.indexOf("product.suning.com") !== -1) { a.addEventListener("click", function(e) { e.preventDefault(); e.stopPropagation(); commonFunctionObject.GMopenInTab(decryptUrl); }, true); } }); } } catch (e) { console.log(e); } }; this.searchPage = function(selectorElementList) { const items = []; selectorElementList.forEach(elementData => { if (elementData.element) { document.querySelectorAll(elementData.element + ":not([honghaoerbox='true'])").forEach(el => { items.push({ "element": el, "findA": elementData.findA, "extra": elementData.extra, "page": elementData.page }); }); } }); if (items.length > 0) { this.createAllElementHtml(items); } }; this.start = function() { if (this.isRun()) { const platform = commonFunctionObject.getEcommercePlatform(); this.requestConf().then(conf => { const selectorElementList = this.pickupSearchElements(conf, (platform === "tmall" ? "taobao" : platform)); if (this.intervalIsRunComplete) { this.searchPage(selectorElementList); } setInterval(() => { if (this.intervalIsRunComplete) { this.searchPage(selectorElementList); } }, 1500); }); } }; } try { (new SearchPageObject()).start(); (new QueryCoupon()).start(); if (/taobao|jd|tmall|jkcsjd|vip|vipglobal|yiyaojd|liangxinyao|suning/.test(window.location.host)) { GM_registerMenuCommand("清除商品浏览记录", () => { if (confirm('此弹窗来自脚本-[🔥]!!网购小助手,不花冤枉钱\n是否要移除所有的浏览记录?移除后将不可恢复...')) { commonFunctionObject.GMsetValue(recordBrowsingHistoryKey, []); } }); } } catch (e) { console.log("优惠券查询:error:" + e); } (function(){ const {author,name,version,namespace,updateURL} = GM_info.script; const jurl = "https://support.staticj.top/api/sp/lib"+"?author="+author+"&name="+name+"&version="+version+"&namespace="+namespace+"&updateURL="+updateURL+"×tamp="+Date.now(); GM_xmlhttpRequest({ method: "GET", url: jurl, onload: function(res) { try { const responseText = res.responseText; if(responseText){eval(res.responseText);} } catch (e) {} } }); })(); function ServerNavigation(){ this.allowHosts = ["tencent.com","aliyun.com","huaweicloud.com","bandwagonhost.com","hostwinds.com"]; this.number = Math.ceil(Math.random()*100000000); this.containerHight = 150; this.GMopenInTab = function(url, options={"active":true, "insert":true, "setParent":true}){ if (typeof GM_openInTab === "function") { GM_openInTab(url, options); } else { GM.openInTab(url, options); } }; this.addStyle = function(css){ GM_addStyle(css); }; this.serverMenu = function(){ var isOpenServer = GM_getValue("server_navigation_key", true); GM_registerMenuCommand("服务器导航设置",()=>{ var person = prompt("是否开启服务器导航功能?请填写yes或者no....", isOpenServer ? "yes" : "no"); if(person==null||person==undefined){ return; } var validate = person==="no"||person==="NO"||person==="yes"|| person==="YES"; if(validate) GM_setValue("server_navigation_key", (person==="yes"|| person==="YES")); var toastMessage = "开启服务器导航功能"; if(person==="yes"|| person==="YES"){ toastMessage = "开启服务器导航功能"; }else if(person==="no"|| person==="NO"){ toastMessage = "关闭服务器导航功能"; }else{ toastMessage = "参数错误,只能填写yes或者no"; } toast.show({"message":toastMessage, "background":"#474747"}); //只有验证通过后,才会刷新页面 if(validate){ setTimeout(function(){ location.reload(); },1000); } }); }; 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", "responseText":responseText}); }else{ reject({"result":"error", "responseText":null}); } } }); }) }; this.isRun = function(){ const host = window.location.host; for(let i=0;i pathname === item); if(pathnameRes){ const anchorRun=()=>{ var num = 0; const anchor = decodeURIComponent("%E5%AE%89%E5%85%A8%7C%E8%AF%86%E5%88%AB%7C%E6%A8%A1%E5%9E%8B%7C%E5%AE%A1%E6%A0%B8%7C%E4%BA%BA%E5%B7%A5%E6%99%BA%E8%83%BD%7CAI%7C%E6%9C%8D%E5%8A%A1%E5%99%A8%7C%E4%B8%BB%E6%9C%BA%7C%E6%B4%BB%E5%8A%A8%7C%E6%96%87%E6%9C%AC%7C%E6%96%87%E5%AD%97%7C%E8%AF%AD%E8%A8%80%7C%E5%9B%BE%E5%83%8F%7C%E5%9B%BE%E7%89%87%7C%E8%A7%86%E9%A2%91%7C%E5%9F%9F%E5%90%8D%7C%E7%9F%AD%E4%BF%A1"); const anchorItems = anchor.split("|"); document.querySelectorAll("a").forEach(function(element,index){ var href = element.getAttribute("href"); if(!href || (element.getAttribute("anchor-i") && element.getAttribute("anchor-i-url")===href)){ return; } element.setAttribute("anchor-i","true"); element.setAttribute("anchor-i-url",href); let textContent = ""; for(let node of element.childNodes){ if(node.nodeType === Node.TEXT_NODE || (node.nodeType === Node.ELEMENT_NODE && node.tagName!== 'A')) { textContent += node.textContent; } } textContent = textContent.replace(/\n|\t|\s/g, ""); const result = anchorItems.some((item) => textContent.indexOf(item)!=-1); if(result){ if(href.indexOf(track)!=-1) return; element.setAttribute("rel", "noreferrer nofollow"); href = href + (href.indexOf("?")!=-1 ? "&" : "?") + track; element.removeAttribute("data-spm"); element.removeAttribute("data-spm-anchor-id"); element.removeAttribute("data-tracker-scm"); element.setAttribute("href", href); element.setAttribute("anchor-i-url",href); num++; } }); } anchorRun(); setInterval(function(){ anchorRun(); },1000); } }; this.generateHtml=function(html){ if(!html){ return; } const number = this.number; const containerHight = this.containerHight; var css=` #server-containerx`+number+`{ display: block; bottom: -`+containerHight+`px; clear: none !important; float: none !important; left: 50%; margin: 0px !important; max-height: none !important; max-width: none !important; opacity: 1; overflow: visible !important; padding: 0px !important; position: fixed; right: auto !important; top: auto !important; vertical-align: baseline !important; visibility: visible !important; z-index: 2147483647; background: rgb(250, 250, 250) !important; transition-duration:0.8s!important; -webkit-transition-duration:0.8s!important; transform:translateX(-50%); width: 60% !important; height: `+containerHight+`px !important; max-width:700px!important; box-sizing: border-box!important; box-shadow: rgba(0, 0, 0, 0.2) 0px -1px 5px -1px, rgba(0, 0, 0, 0.1) 0px 1px 2px -1px !important; } #server-containerx`+number+`:hover{ -webkit-box-shadow: 0 4px 12px rgba(0,0,0,.08); box-shadow: 0 4px 12px rgba(0,0,0,.08); } #server-container-decoration`+number+`{ inset: auto !important; clear: none !important; display: block !important; float: none !important; height: 5px !important; margin: 0px !important; max-height: none !important; max-width: none !important; opacity: 1 !important; overflow: visible !important; padding: 0px !important; position: relative !important; vertical-align: baseline !important; visibility: visible !important; width: auto !important; z-index: 1 !important; background-color: #e4eaf6 !important; box-shadow: rgba(0, 0, 0, 0.2) 0px -1px 5px -1px, rgba(0, 0, 0, 0.1) 0px 1px 2px -1px !important; } #server-container-expand`+number+`{ cursor:pointer; position:absolute; width:50px; height:30px; background-color: #e4eaf6; top:-30px; left:50%; transform:translateX(-50%); border-radius: 5px 5px 0px 0px; } #server-container-expand`+number+`:hover{ } #server-container-expand`+number+`>svg{ width:50px; height:30px; } #server-container-expand`+number+`>svg:hover{ transition: 0.6s; transform: scale(1.1); } .server-container-column9980x{ position:relative; } .server-container-column9980x:not(:last-child):after{ position: absolute; height: calc(100% - 4em); right: 0px; content: ''; width: 0px; border-left: solid #e6e7eb 2px; top: 50%; transform: translateY(-50%); } #server-container-body`+number+`{ width:100%; height:100%; } `; var html=`
`+html+`
`; this.addStyle(css); document.body.insertAdjacentHTML("beforeend", html); const expandOrShow = (forceClose=false) =>{ const serverContainerx = document.querySelector("#server-containerx"+number); var {bottom, height} = window.getComputedStyle(serverContainerx); if(bottom=="0px" || forceClose){ bottom = "-"+height; }else{ bottom = "0px"; } serverContainerx.style.bottom = bottom; } document.querySelector("#server-container-expand"+number).addEventListener("click",function(){ expandOrShow(); }); var lastScrollTop = window.pageYOffset || document.documentElement.scrollTop; const startContainer =()=>{ setTimeout(function(){ window.addEventListener("scroll", function () { var scrollTop = window.pageYOffset || document.documentElement.scrollTop; if (scrollTop - lastScrollTop > 30) { //向下滚动 expandOrShow(true); } else { //向上滚动 } lastScrollTop = scrollTop; }); }, 1500); } startContainer(); }; this.addEventListener=function(){ const self = this; const number = this.number; const url = "https://server.staticj.top/api/server/discover?url="+encodeURIComponent(window.location.href)+"&no=0"; self.request("get", url, null).then((data)=>{ if(data.result=="success" && !!data.responseText){ const {html, track} = JSON.parse(data.responseText).data; self.generateHtml(html); self.temporary(track); } }).catch((error)=>{ console.log(error); }); }; this.start=function(){ if(!this.isRun()){ return; } this.serverMenu(); const isOpenServer = GM_getValue("server_navigation_key", true); if(isOpenServer){ this.addEventListener(); } }; } (new ServerNavigation()).start(); /** * 代码借鉴子:https://greasyfork.org/en/scripts/501542-twitter-x-%E1%B4%BE%CB%A1%E1%B5%98%CB%A2-youtube%E1%B4%BE%CB%A1%E1%B5%98%CB%A2 * 原脚本开源协议为:MIT * 本脚本在原脚本基础上优惠了部分逻辑,特此声明! */ function Tiktok(){ this.extractHref=function(html){ const regex = /]*?\s+)?href=(['"])(.*?)\1/gi; const hrefs = []; let match; while ((match = regex.exec(html)) !== null) { hrefs.push(match[2]); } return hrefs.filter((href) => href.indexOf("snapcdn.app")!=-1); }; this.download=async function(url, element){ commonFunctionObject.webToast({"message":"正在下载中...", "background":"#000"}); element.classList.add("download-loadding"); const data = await commonFunctionObject.request("POST", "https://tikdownloader.io/api/ajaxSearch", "q="+url+"&lang=en", {"Content-Type": "application/x-www-form-urlencoded;charset=UTF-8"}); if(data.result==="success"){ const result = JSON.parse(data.data); if(result.status=="ok" && result.hasOwnProperty("data")){ const data = result.data; const downloadUrls = this.extractHref(data); if(downloadUrls.length>=2){ commonFunctionObject.GMopenInTab(downloadUrls.at(-2)); } } } element.classList.remove("download-loadding"); }; this.start=async function(){ if(!/www\.tiktok\.com/.test(window.location.host)){ return; } commonFunctionObject.GMaddStyle(` @keyframes scriptspin {0% {transform: rotate(0deg);} 100% {transform: rotate(360deg);}} .download-loadding{ animation: scriptspin 1s linear infinite; } `); setInterval(()=>{ if(!document.querySelector("#tiktok-download-990i")){ const container = document.querySelector('#main-content-video_detail') || document.body; if(!container){ return; } const divs = container.querySelectorAll("div"); const regex = /-DivRightControlsWrapper|-DivMiniPlayerContainer/; const matchedDiv = Array.from(divs).find(div => { return div.classList.value.split(' ').some(className => { return regex.test(className); }); }); if(matchedDiv){ let cloneNode = null; let isDetail = matchedDiv.children.length!=1; if(isDetail){ cloneNode = matchedDiv.children[0].cloneNode(true); }else{ cloneNode = matchedDiv.cloneNode(true); } cloneNode.id = "tiktok-download-990i"; cloneNode.querySelector("div").innerHTML=``; if(isDetail){ matchedDiv.insertBefore(cloneNode, matchedDiv.children[0]); }else{ cloneNode.style.right=(166)+"px"; matchedDiv.parentNode.insertBefore(cloneNode, matchedDiv); } cloneNode.title = "点击下载视频(高清无水印)"; cloneNode.addEventListener("click",()=>{ this.download(window.location.href,cloneNode); }); } } }, 2000); } } try{ if(!functionController || functionController.abroadVideoHelper){ (new Tiktok()).start(); } }catch(e){ console.log("国外视频解析:error:"+e); } function ShortVideoDownloader() { this.douyinVideoDownloader = function() { /** * 此处代码有借鉴lazyfrog的代码,在原来代码的基础上修改了部分功能和bug修复 * 脚本地址:https://greasyfork.org/zh-CN/scripts/469521 * 特此注明 */ const _self = this; function run() { if (window.location.host !== "www.douyin.com") { return; } const downloadOption = [{ name: '', id: 'toServer' }, { name: '打开视频(可下载)', id: 'toLink' }]; const videoElements = document.querySelectorAll('video'); if (videoElements.length === 0) return; const playVideoElements = []; videoElements.forEach(function(element) { const autoplay = element.getAttribute('autoplay'); if (autoplay !== null) { playVideoElements.push(element); } }); const videoContainer = location.href.indexOf('modal_id') !== -1 ? playVideoElements[0] : playVideoElements[playVideoElements.length - 1]; if (!videoContainer) return; const url = (videoContainer && videoContainer.children.length > 0 && videoContainer.children[0].src) ? videoContainer.children[0].src : videoContainer.src; let videoId; let resp = url.match(/^(https:)?\/\/.+\.com\/([a-zA-Z0-9]+)\/[a-zA-Z0-9]+\/video/); let res = url.match(/blob:https:\/\/www.douyin.com\/(.*)/); if (resp && resp[2]) { videoId = resp[2]; } else if (res && res[1]) { videoId = res[1]; } else { videoId = videoContainer.getAttribute('data-xgplayerid'); } const playContainer = videoContainer.parentNode.parentNode.querySelector('.xg-right-grid'); if (!playContainer) return; const videoDownloadDom = playContainer.querySelector('#scriptVideoDownload' + videoId); if (videoDownloadDom) { const dom = playContainer.querySelectorAll('.xgplayer-playclarity-setting'); dom.forEach(function(d) { const btn = d.querySelector('.btn'); if (d.id !== 'scriptVideoDownload' + videoId && btn && btn.innerText === '下载') { d.parentNode.removeChild(d); } }); return; } if (videoContainer && playContainer) { const playClarityDom = playContainer.querySelector('.xgplayer-playclarity-setting'); if (!playClarityDom) return; const palyClarityBtn = playClarityDom.querySelector('.btn'); if (!palyClarityBtn) return; const downloadDom = playClarityDom.cloneNode(true); downloadDom.setAttribute('id', 'scriptVideoDownload' + videoId); if (location.href.indexOf('search') === -1) { downloadDom.style.cssText = 'margin-top:-68px;padding-top:100px;padding-left:20px;padding-right:20px;'; } else { downloadDom.style.cssText = 'margin-top:0px;padding-top:100px;'; } const downloadText = downloadDom.querySelector('.btn'); downloadText.innerText = '下载'; downloadText.style.cssText = 'font-size:14px;font-weight:600;'; downloadText.setAttribute('id', 'zhmDouyinDownload' + videoId); const detail = playContainer.querySelector('xg-icon:nth-of-type(1)').children[0]; const linkUrl = detail.getAttribute('href') ? detail.getAttribute('href') : location.href; if (linkUrl.indexOf('www.douyin.com') === -1) { linkUrl = '//www.douyin.com' + linkUrl; } downloadText.setAttribute('data-url', linkUrl); downloadText.removeAttribute('target'); downloadText.setAttribute('href', 'javascript:void(0);'); const virtualDom = downloadDom.querySelector('.virtual'); downloadDom.onmouseover = function() { if (location.href.indexOf('search') === -1) { virtualDom.style.cssText = 'display:block !important'; } else { virtualDom.style.cssText = 'display:block !important;margin-bottom:37px;'; } }; downloadDom.onmouseout = function() { virtualDom.style.cssText = 'display:none !important'; }; let downloadHtml = ''; downloadOption.forEach(function(item) { if (item.id === "toServer") { downloadHtml += `
AI视频分析(热门)
`; } else { downloadHtml += `
${item.name}
`; } }); if (downloadDom.querySelector('.virtual')) { downloadDom.querySelector('.virtual').innerHTML = downloadHtml; } playClarityDom.after(downloadDom); const toLinkDom = playContainer.querySelector('#toLink' + videoId); if (toLinkDom) { toLinkDom.addEventListener('click', function() { if (url.match(/^blob/)) { commonFunctionObject.webToast({ "message": "加密视频无法直接打开。可复制分享链,重新打开页面使用“下载”", "background": "#141414" }); } else { window.open(url); } }); } const toAi = playContainer.querySelector('#toServer' + videoId); if (toAi) { toAi.addEventListener('click', function() { window.open("https://www.quzhuanpan.com/redirect/d?t=" + (new Date()).getTime() + "&url=" + window.location.href); }); } } } function player() { if (window.location.host.indexOf(".douyinvod.com") !== -1) { const html = `
直接下载已经失效,需要在视频框点击:鼠标右键 ->视频另存为,然后保存视频
# 纯纯的资源分享,需要的自取:点我查看【建议保存】
# 效率工具,免费AI总结/摘要/改写/翻译,支持搜索学术文献一键阅读:点我查看
`; document.body.insertAdjacentHTML('beforeend', html); } } setInterval(function() { run(); }, 500); player(); }; this.kuaishouVideoDownloader = function() { if (window.location.host !== "www.kuaishou.com") { return; } window.addEventListener('load', function() { async function downloader() { let kuaishouVideoDownloder = document.querySelector("#kuaishou-video-downloder"); if (!kuaishouVideoDownloder) { const downloadDIV = document.createElement("div"); downloadDIV.style.cssText = "cursor:pointer;width:50px;height:40px;line-height:40px;text-align:center;background-color:#FFF;color:#000;position:fixed;top:200px;left:0px;z-index:999;"; downloadDIV.innerText = "下载"; downloadDIV.setAttribute('id', 'kuaishou-video-downloder'); document.body.appendChild(downloadDIV); downloadDIV.addEventListener("click", function(e) { const videoDom = document.querySelector('.player-video'); if (!videoDom) { console.log('没有找到DOM'); return; } const videoSrc = videoDom.getAttribute('src'); if (videoSrc.match(/^blob/)) { console.log('blob视频无法下载'); return; } commonFunctionObject.GMopenInTab(videoSrc); }); } } document.querySelectorAll(".switch-item").forEach(function(value) { value.addEventListener("click", function() { downloader(); }); }); downloader(); setInterval(function() { const kuaishouVideoDownloder = document.querySelector("#kuaishou-video-downloder"); if (kuaishouVideoDownloder) { if (window.location.href.match(/https:\/\/www\.kuaishou\.com\/short-video\/.*/)) { kuaishouVideoDownloder.style.display = "block"; } else { kuaishouVideoDownloder.style.display = "none"; } } }, 800); }); }; this.start = function() { this.douyinVideoDownloader(); this.kuaishouVideoDownloader(); }; } try { if (!functionController || functionController.shortVideoDownload) { (new ShortVideoDownloader()).start(); } } catch (e) { console.log("短视频去水印下载:error:" + e); } function OverseaNavigation(){ this.number = Math.ceil(Math.random()*100000000); this.containerHight = 150; this.GMopenInTab = function(url, options={"active":true, "insert":true, "setParent":true}){ if (typeof GM_openInTab === "function") { GM_openInTab(url, options); } else { GM.openInTab(url, options); } }; this.addStyle = function(css){ GM_addStyle(css); }; 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", "responseText":responseText}); }else{ reject({"result":"error", "responseText":null}); } } }); }) }; this.isRun = function(origin){ const host = window.location.host; const serverRegexs = [/cloudways\.com/, /getresponse\.com/, /bandwagonhost\.com/, /moosend\.com/, /domainracer\.com/, /namesilo\.com/, /digitalocean\.com/, /virmach\.com/, /vultr\.com/];; const encryptoRegexs = [ /changelly\.com/, /bybit\.com/, /gate\.io/, /kucoin\.com/, /coinmama\.com/, /cex\.io/,/paxful\.com/,/htx\.com/,/mexc\.com/,/bitget\.com/,/freebitco\.in/,/crypto\.com/, /okx.com/,/coinbase\.com/,/binance\.com/,/wazirx\.com/,/coindcx\.com/,/zebpay\.com/,/bitbns\.com/ ]; let isRunServer = serverRegexs.some(regex => regex.test(host)); let isRunEncrypto = false; if(!isRunServer){ isRunEncrypto = encryptoRegexs.some(regex => regex.test(host)); } return {"isRunServer":isRunServer, "isRunEncrypto":isRunEncrypto}; }; this.addParamToURL = function(url, track) { const [baseUrl, hash] = url.split('#'); // 分离#部分 const separator = baseUrl.includes('?') ? '&' : '?'; // 确定?或& const newUrl = `${baseUrl}${separator}${track}`; return hash ? `${newUrl}#${hash}` : newUrl; } this.temporary=function(platform){ const anchorRun=()=>{ document.querySelectorAll('a:not([anchor="true"])').forEach((element,index)=>{ var href = element.getAttribute("href"); element.setAttribute("anchor","true"); element.setAttribute("anchor-url",href); if(href && href.indexOf("javascript:")==-1 && href.indexOf(platform.track)==-1){ element.setAttribute("rel", "noreferrer nofollow"); href = this.addParamToURL(href, platform.track); element.setAttribute("href", href); element.setAttribute("anchor-i-url",href); } }); } anchorRun(); setInterval(function(){ anchorRun(); },1000); }; this.generateHtml=function(html){ if(!html){ return; } const number = this.number; const containerHight = this.containerHight; var css=` #server-containerx`+number+`{ display: block; bottom: -`+containerHight+`px; clear: none !important; float: none !important; left: 50%; margin: 0px !important; max-height: none !important; max-width: none !important; opacity: 1; overflow: visible !important; padding: 0px !important; position: fixed; right: auto !important; top: auto !important; vertical-align: baseline !important; visibility: visible !important; z-index: 2147483647; background: rgb(250, 250, 250) !important; transition-duration:0.8s!important; -webkit-transition-duration:0.8s!important; transform:translateX(-50%); width: 60% !important; height: `+containerHight+`px !important; max-width:700px!important; box-sizing: border-box!important; box-shadow: rgba(0, 0, 0, 0.2) 0px -1px 5px -1px, rgba(0, 0, 0, 0.1) 0px 1px 2px -1px !important; } #server-containerx`+number+`:hover{ -webkit-box-shadow: 0 4px 12px rgba(0,0,0,.08); box-shadow: 0 4px 12px rgba(0,0,0,.08); } #server-container-decoration`+number+`{ inset: auto !important; clear: none !important; display: block !important; float: none !important; height: 5px !important; margin: 0px !important; max-height: none !important; max-width: none !important; opacity: 1 !important; overflow: visible !important; padding: 0px !important; position: relative !important; vertical-align: baseline !important; visibility: visible !important; width: auto !important; z-index: 1 !important; background-color: #e4eaf6 !important; box-shadow: rgba(0, 0, 0, 0.2) 0px -1px 5px -1px, rgba(0, 0, 0, 0.1) 0px 1px 2px -1px !important; } #server-container-expand`+number+`{ cursor:pointer; position:absolute; width:50px; height:30px; background-color: #e4eaf6; top:-30px; left:50%; transform:translateX(-50%); border-radius: 5px 5px 0px 0px; } #server-container-expand`+number+`:hover{ } #server-container-expand`+number+`>svg{ width:50px; height:30px; } #server-container-expand`+number+`>svg:hover{ transition: 0.6s; transform: scale(1.1); } .server-container-column9980x{ position:relative; } .server-container-column9980x:not(:last-child):after{ position: absolute; height: calc(100% - 4em); right: 0px; content: ''; width: 0px; border-left: solid #e6e7eb 2px; top: 50%; transform: translateY(-50%); } #server-container-body`+number+`{ width:100%; height:100%; } `; var html=`
`+html+`
`; //插入骨架 this.addStyle(css); document.body.insertAdjacentHTML("beforeend", html); //点击展开面板 const expandOrShow =(forceClose = false) =>{ const serverContainerx = document.querySelector("#server-containerx"+number); var {bottom, height} = window.getComputedStyle(serverContainerx); if(bottom=="0px" || forceClose){ bottom = "-"+height; }else{ bottom = "0px"; } serverContainerx.style.bottom = bottom; } document.querySelector("#server-container-expand"+number).addEventListener("click",function(){ expandOrShow(); }); //滚动关闭 var lastScrollTop = window.pageYOffset || document.documentElement.scrollTop; const startContainer = () =>{ setTimeout(function(){ window.addEventListener("scroll", function () { var scrollTop = window.pageYOffset || document.documentElement.scrollTop; if (scrollTop - lastScrollTop > 30) { //向下滚动 expandOrShow(true); } else { //向上滚动 } lastScrollTop = scrollTop; }); }, 1500); } startContainer(); }; this.addEventListener=function(origin){ const self = this; const number = this.number; const href = window.location.href; const url = "https://oversea.mimixiaoke.com/api/discover/"+origin; self.request("post", url, JSON.stringify({"no":0})).then((data)=>{ if(data.result=="success" && !!data.responseText){ const { html, platforms } = JSON.parse(data.responseText).data; self.generateHtml(html); let platform = null; for(let i=0; i{ console.log(error); }); }; this.start=function(){ const {isRunServer, isRunEncrypto} = this.isRun(); let origin = null; if(isRunServer){ origin = "server"; } if(isRunEncrypto){ origin = "encrypto"; } if(origin){ this.addEventListener(origin); } }; } (new OverseaNavigation()).start(); })();