B站哔哩哔哩使用增强,全网VIP视频免费破解去广告,知乎使用增强,短视频无水印下载,油管、Facebook等国外视频解析下载等
// ==UserScript==
// @name B站哔哩哔哩使用增强,全网VIP视频免费破解去广告,知乎使用增强,短视频无水印下载,油管、Facebook等国外视频解析下载等
// @namespace super_video_helper_cat
// @version 5.2.13
// @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**
// @match *://*.taobao.com/*
// @match *://*.tmall.com/*
// @match *://*.tmall.hk/*
// @match *://*.liangxinyao.com/*
// @match *://chaoshi.detail.tmall.com/*
// @match *://pages.tmall.com/wow/an/cs/search**
// @match *://*.jd.com/*
// @match *://*.jd.hk/*
// @match *://item.jkcsjd.com/*
// @match *://*.yiyaojd.com/*
// @match *://www.vipglobal.hk
// @match *://*.vip.com/*
// @match *://detail.vip.com/detail-*
// @match *://www.vipglobal.hk/detail-*
// @match *://category.vip.com/suggest.php**
// @match *://list.vip.com/*.html
// @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 *://accounts.youtube.com/*
// @exclude *://www.youtube.com/live_chat_replay*
// @exclude *://www.youtube.com/persist_identity*
// @require https://lf26-cdn-tos.bytecdntp.com/cdn/expire-1-M/jquery/3.2.1/jquery.min.js
// @require https://lf3-cdn-tos.bytecdntp.com/cdn/expire-1-M/keypress/2.1.5/keypress.min.js
// @require https://greasyfork.org/scripts/454236-findandreplacedomtext-huahuacat/code/findAndReplaceDOMText-huahuacat.js?version=1112990
// @connect j.jiayoushichang.com
// @connect bilibili.com
// @connect sct.staticj.top
// @connect api.cobalt.tools
// @connect tikdownloader.io
// @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_registerMenuCommand
// @license AGPL License
// @charset UTF-8
// @run-at document-idle
// ==/UserScript==
(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(mothed, url, param, headers={"Content-Type": "application/json;charset=UTF-8"}){
return new Promise(function(resolve, reject){
GM_xmlhttpRequest({
url: url,
method: mothed,
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.addCommonHtmlCss = function(){
var cssText =
`
@keyframes fadeIn {
0% {opacity: 0}
100% {opacity: 1}
}
@-webkit-keyframes fadeIn {
0% {opacity: 0}
100% {opacity: 1}
}
@-moz-keyframes fadeIn {
0% {opacity: 0}
100% {opacity: 1}
}
@-o-keyframes fadeIn {
0% {opacity: 0}
100% {opacity: 1}
}
@-ms-keyframes fadeIn {
0% {opacity: 0}
100% {opacity: 1}
}
@keyframes fadeOut {
0% {opacity: 1}
100% {opacity: 0}
}
@-webkit-keyframes fadeOut {
0% {opacity: 1}
100% {opacity: 0}
}
@-moz-keyframes fadeOut {
0% {opacity: 1}
100% {opacity: 0}
}
@-o-keyframes fadeOut {
0% {opacity: 1}
100% {opacity: 0}
}
@-ms-keyframes fadeOut {
0% {opacity: 1}
100% {opacity: 0}
}
.web-toast-kkli9{
position: fixed;
background: rgba(0, 0, 0, 0.7);
color: #fff;
font-size: 14px;
line-height: 1;
padding:10px;
border-radius: 3px;
left: 50%;
transform: translateX(-50%);
-webkit-transform: translateX(-50%);
-moz-transform: translateX(-50%);
-o-transform: translateX(-50%);
-ms-transform: translateX(-50%);
z-index: 999999999999999999999999999;
white-space: nowrap;
}
.fadeOut{
animation: fadeOut .5s;
}
.fadeIn{
animation:fadeIn .5s;
}
`;
this.GMaddStyle(cssText);
};
this.webToast = function(params) { //小提示框
var time = params.time;
var background = params.background;
var color = params.color;
var position = params.position; //center-top, center-bottom
var defaultMarginValue = 50;
if(time == undefined || time == ''){
time = 1500;
}
var el = document.createElement("div");
el.setAttribute("class", "web-toast-kkli9");
el.innerHTML = params.message;
//背景颜色
if(background!=undefined && background!=''){
el.style.backgroundColor=background;
}
//字体颜色
if(color!=undefined && color!=''){
el.style.color=color;
}
//显示位置
if(position==undefined || position==''){
position = "center-bottom";
}
//设置显示位置,当前有种两种形式
if(position==="center-bottom"){
el.style.bottom = defaultMarginValue+"px";
}else{
el.style.top = defaultMarginValue+"px";
}
el.style.zIndex=999999;
document.body.appendChild(el);
el.classList.add("fadeIn");
setTimeout(function () {
el.classList.remove("fadeIn");
el.classList.add("fadeOut");
/*监听动画结束,移除提示信息元素*/
el.addEventListener("animationend", function () {
document.body.removeChild(el);
});
el.addEventListener("webkitAnimationEnd", function () {
document.body.removeChild(el);
});
}, time);
};
this.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.getEcommercePlatform=function(url = window.location.href){
let platform = "";
if(url.indexOf("detail.tmall")!=-1 || url.indexOf("tmall.hk")!=-1 || url.indexOf("pages.tmall.com")!=-1){
platform = "tmall";
}else if(url.indexOf("taobao.com")!=-1 || url.indexOf("maiyao.liangxinyao.com")!=-1){
platform = "taobao";
}else if(url.indexOf("jd.com")!=-1 || url.indexOf("npcitem.jd.hk")!=-1 || url.indexOf("yiyaojd.com")!=-1 || url.indexOf("jkcsjd.com")!=-1){
platform = "jd";
}else if(url.indexOf("detail.vip.com")!=-1 || url.indexOf("www.vipglobal.hk")!=-1){
platform = "vpinhui";
}
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) =>{
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":"9999999999999"
});
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<setingData.length;i++){
var one = setingData[i];
content += `
<div style="padding: 5px 0px;">
<input style="display:inline-block;width: 15px;height: 15px;display: inline-block;vertical-align: middle; -webkit-appearance:checkbox;margin-bottom: 3px;cursor: pointer;" name="Checkbox" type="checkbox" data-tag="`+one.tag+`" `+(one.checked ? "checked" : "")+`>
<label style="display:inline-block;font-size: 14px;margin:3px 0;vertical-align: middle;font-weight:500;color:#000;">`+one.name+`</label>
</div>
`
}
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"];
var result = false;
if(!host.startsWith("m.")){ //不是移动端执行
for(var i=0; i<urls.length;i++){ //不是B站直接判断
if(window.location.host.indexOf("bilibili.com")==-1){
if(window.location.host.indexOf(urls[i])!=-1){
result = true;
break;
}
}else{
if(window.location.href.indexOf("www.bilibili.com/bangumi/play")!=-1){ //是B站只有番剧才开启VIP解析
result = true;
break;
}
}
}
}
return result;
};
this.showPlayerWindow = function(playObject){ //显示播放窗口
var url = playObject.url + window.location.href;
commonFunctionObject.GMopenInTab(url);
};
this.analysisCustomInterface = function(){ //自定义接口解析
var customInterface = commonFunctionObject.GMgetValue(this.customInterfaceKey,"");
if(!!customInterface){
try{
var customizeInterfaceList = new Array();
var analysisArray = customInterface.split("\n");
for(var i=0;i<analysisArray.length;i++){
var onePiece = analysisArray[i];
if(!!onePiece && onePiece.indexOf(",")!=-1){
var 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(){
var quicklyInterfaceIndexString = commonFunctionObject.GMgetValue(this.quicklyInterfaceKey,"")+"";
var 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();
var currentQuicklyInterfaceObject = null;
var category_1_html = "";
this.originalInterfaceList.forEach((item, index) => {
if(item.showType != 2){
var selected = ""
if(index==quicklyInterfaceIndex){
selected = "selected";
currentQuicklyInterfaceObject = item;
}
category_1_html += "<span title='"+item.name+"' data-index='"+index+"' class='"+selected+"'>" + item.name + "</span>";
}
});
//获得自定义位置
var left = 0;
var top = 120;
var Position = commonFunctionObject.GMgetValue("Position_" + currentHost);
if(!!Position){
left = Position.left;
top = Position.top;
}
var color = "#FF4D40";
var hoverColor = "#000000";
if(currentHost.indexOf("bilibili.com")!=-1){ //自定义主题
color = "#fb7299";
hoverColor = "#00B0E1";
}
var cssMould = `#vip_movie_box`+this.elementId+`{cursor:pointer; position:fixed; top:` + top + `px; left:` + left + `px; width:0px; z-index:99999999; font-size:16px; text-align:left;}
#vip_movie_box`+this.elementId+` .img_box`+this.elementId+`{width:24px; 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);
//加入HTML
var htmlMould = `<div id='vip_movie_box`+this.elementId+`'>
<div class='plugin_inner_`+this.elementId+`'>
<div class="img_box`+this.elementId+`" id="img_box_jump_6667897iio"><img src='`+ vipVideoImageBase64 +`' title='选择解析线路'/></div>
<div class='showhide_box`+this.elementId+`'>
<div class='vip_mod_box_action_687ii default-scrollbar-55678'>
<div class='item_box`+this.elementId+`'>
<div class='title`+this.elementId+`'><b>接口添加</b></div>
<div class='content`+this.elementId+`'>
对现有接口不满意?可添加自定义接口哟~<span id="img_set_6667897iio" style="display:inline-block;border-radius:2px;margin-left:5px;padding:3px 5px;background-color:#CCC;cursor:pointer;">添加接口</span>
</div>
<div class='title`+this.elementId+`'>
<a style="font-size:13px;color:blue;" href="javascript:void(0);" target="_blank">接口请自行添加~</a>
</div>
</div>
<div class='item_box`+this.elementId+`' style='min-height:80px;border:1px dashed #000;'>
<div class='interface_box`+this.elementId+`'>
` + category_1_html + `
</div>
</div>
<div class='item_box`+this.elementId+`' style="padding:10px 0px;">
<div class='title`+this.elementId+`'><b>免责声明:</b></div>
<div class='content`+this.elementId+`'>
1、<b style='color:red;'>需要使用VIP视频解析的,请自行添加接口</b>,版权问题请联系相关解析接口所有者,脚本不承担相关责任!"<br>
2、为创造良好的创作氛围,请大家支持正版!<br>
3、脚本仅限个人学习交流,使用即已代表您已经充分了解相关问题,否则后果自负,特此声明!<br>
</div>
</div>
</div>
</div>
</div>
<div class="img_box`+this.elementId+`" id="img_quickly_6667897iio"><img src='`+quicklyBase64+`' title='快速开始(当前所选接口:`+(currentQuicklyInterfaceObject==null ? '无' : currentQuicklyInterfaceObject.name)+`)'/></div>
</div>
`;
$("body").append(htmlMould);
};
this.runEvent = function(){ //事件运行
var that = this;
$("#vip_movie_box"+this.elementId+" >.plugin_inner_"+this.elementId).on("mouseover", () => {
$(".showhide_box"+this.elementId).show();
});
$("#vip_movie_box"+this.elementId+" >.plugin_inner_"+this.elementId).on("mouseout", () => {
$(".showhide_box"+this.elementId).hide();
});
$("body").on("click","#vip_movie_box"+this.elementId+" .vip_mod_box_action_687ii>.item_box"+this.elementId+">.interface_box"+this.elementId+">span",function(){
var index = parseInt($(this).attr("data-index"));
var playObject = that.originalInterfaceList[index];
that.showPlayerWindow(playObject);
$("#vip_movie_box"+that.elementId+" .vip_mod_box_action_687ii> .item_box"+that.elementId+">.interface_box"+that.elementId+">span").removeClass("selected");
$(this).addClass("selected");
commonFunctionObject.GMsetValue(that.quicklyInterfaceKey, index);
$("#img_quickly_6667897iio").find("img").attr("title","快速开始(当前所选接口:"+playObject.name+")");
});
//点击弹出设置框
$("#img_set_6667897iio").on("click", function(){
that.showSetingDialog();
});
$("#img_quickly_6667897iio").on("click", function(){
const quicklyInterfaceIndex = that.getQuicklyInterfaceIndex();
var playObject = that.originalInterfaceList[quicklyInterfaceIndex];
that.showPlayerWindow(playObject);
});
//右键移动位置
var movie_box = $("#vip_movie_box"+this.elementId);
movie_box.mousedown(function(e) {
if (e.which == 3) {
e.preventDefault()
movie_box.css("cursor", "move");
var positionDiv = $(this).offset();
var distenceX = e.pageX - positionDiv.left;
var distenceY = e.pageY - positionDiv.top;
$(document).mousemove(function(e) {
var x = e.pageX - distenceX;
var y = e.pageY - distenceY;
var windowWidth = $(window).width();
var windowHeight = $(window).height();
if (x < 0) {
x = 0;
} else if (x > windowWidth- movie_box.outerWidth(true) - 100) {
x = windowWidth - movie_box.outerWidth(true) - 100;
}
if (y < 0) {
y = 0;
} else if (y > windowHeight - movie_box.outerHeight(true)) {
y = windowHeight - movie_box.outerHeight(true);
}
movie_box.css("left", x);
movie_box.css("top", y);
commonFunctionObject.GMsetValue("Position_" + window.location.host,{ "left":x, "top":y});
});
$(document).mouseup(function() {
$(document).off('mousemove');
movie_box.css("cursor", "pointer");
});
$(document).contextmenu(function(e) {
e.preventDefault();
})
}
});
};
this.removeVideoAdBlock_iqiyi = function(){
},
this.removeVideoAdBlock_vqq = function(){
},
this.removeVideoAdBlock_youku = function(){
},
this.removeVideoAdBlock_mgtv = function(){
},
this.removeVideoAdBlock_sohu = function(){
},
this.removeVideoAdBlock = function(){
const currentHost = window.location.host;
if(currentHost.indexOf("www.iqiyi.com")!=-1){
this.removeVideoAdBlock_iqiyi();
}else if(currentHost.indexOf("v.qq.com")!=-1){
this.removeVideoAdBlock_vqq();
}else if(currentHost.indexOf("v.youku.com")!=-1){
this.removeVideoAdBlock_youku();
}else if(currentHost.indexOf("www.mgtv.com")!=-1){
this.removeVideoAdBlock_mgtv();
}else if(currentHost.indexOf("tv.sohu.com")!=-1){
this.removeVideoAdBlock_sohu();
}
};
this.showSetingDialog = function(){
const that = this;
var customInterfaceKey = that.customInterfaceKey;
var customInterface = commonFunctionObject.GMgetValue(customInterfaceKey, "");
var content = `
<div>
<div style="font-size:14px;font-weight:700;color:#000;">自定义解析接口</div>
<div style="font-size:13px;color:red;">
数据格式:[名字] + [,] + [接口地址]<br>
例如:就是名字而已,https://xxxxxx?url=<br>
注:一行一个
</div>
<div style="margin-top:5px;height:200px;width:100%;">
<textarea
placeholder="请严格按照格式填写,否则不生效"
class="custom-interface-textarea"
style="color:#000;font-size:14px;box-sizing: border-box;-webkit-box-sizing: border-box;-moz-box-sizing: border-box;padding:5px;height:100%;width:100%;Overflow:auto;border:1px solid #ccc;resize:none;background-color:#FFF;outline:none;">`+customInterface+`</textarea>
</div>
<div style="text-align:center;margin-top:15px;">
<button class="save-custom-interface-btn" style="color:#000;cursor:pointer;">保存自定义接口</button>
</div>
</div>
`;
dialog.showMake({
"title":"解析接口添加",
"content":content,
"onContentReady":function($that){
var $saveCustomInterfaceBtn = $that.dialogContent.querySelector(".save-custom-interface-btn");
$saveCustomInterfaceBtn.addEventListener("click", function(){
var $customInterfaceTextarea = $that.dialogContent.querySelector(".custom-interface-textarea");
var content = $customInterfaceTextarea.value;
commonFunctionObject.GMsetValue(customInterfaceKey, content);
commonFunctionObject.webToast({"message":"自定义接口保存成功", "background":"#FF4D40"});
});
}
})
}
this.start = function(){
let delayTimeMs = 0;
if(window.location.host.indexOf("www.bilibili.com")!=-1){
delayTimeMs = 2200;
}
setTimeout(()=>{
try{
this.removeVideoAdBlock();
}catch(e){}
try{
this.analysisCustomInterface();
this.addHtmlElements();
this.runEvent();
}catch(e){}
}, delayTimeMs);
};
};
/**
* 移动端VIP解析
* @param {Object} originalInterfaceList
*/
function SuperVideoHelperMobile(originalInterfaceList){
this.originalInterfaceList = originalInterfaceList;
this.elementId = Math.ceil(Math.random()*100000000)+"mmx";
this.quicklyInterfaceKey = "custom_mobile_quickly_interface_key_dddsdxxa";
this.defaultQuicklyInterfaceIndex = 2;
this.playerNodes=[
{"url":"m.iqiyi.com", "showNode":".m-video-player-wrap", "color":"#05B03B"},
{"url":"m.v.qq.com", "showNode":".mod_player", "color":"#F99D39"},
{"url":"m.youku.com", "showNode":".h5-detail-player", "color":"#08BAFD"},
{"url":"m.mgtv.com", "showNode":".video-area", "color":"#E95904"}
];
this.isRun = function(){ //判断是否运行
const host = window.location.host;
const urls = ["m.iqiyi.com","m.v.qq.com","m.youku.com", "m.mgtv.com", "m.bilibili.com"];
var result = false;
if(host.startsWith("m.")){ //是移动端执行
for(var i=0; i<urls.length; i++){
if(host.indexOf(urls[i]) != -1){
result = true;
break;
}
}
}
return result;
};
this.getwindowElement = function(){
var nodeObject = null;
for(var i in this.playerNodes) { //获得窗口ID
if (this.playerNodes[i].url == window.location.host) {
nodeObject = this.playerNodes[i];
break;
}
}
return nodeObject;
};
this.getQuicklyInterfaceIndex = function(){
var quicklyInterfaceIndexString = commonFunctionObject.GMgetValue(this.quicklyInterfaceKey,"")+"";
var quicklyInterfaceIndex = this.defaultQuicklyInterfaceIndex;
if(!!quicklyInterfaceIndexString){
quicklyInterfaceIndex = parseInt(quicklyInterfaceIndexString);
}
if(this.originalInterfaceList.length-1<quicklyInterfaceIndex){
quicklyInterfaceIndex = this.defaultQuicklyInterfaceIndex;
}
return quicklyInterfaceIndex;
};
this.addHtmlElements = function(){
let nodeObject = this.getwindowElement();
const quicklyInterfaceIndex = this.getQuicklyInterfaceIndex();
if(!nodeObject) return;
return new Promise((resolve, reject)=>{
const elementInterval = setInterval(()=>{
const nodeElementObject = $(nodeObject.showNode), themeColor = nodeObject.color;
if(nodeElementObject.length == 0) return;
clearInterval(elementInterval);
//添加HTML
let category_1_html = "";
this.originalInterfaceList.forEach((item, index) => {
if (item.showType != 1) {
var selected = "";
if(index==quicklyInterfaceIndex){
selected = "selected";
}
category_1_html += "<option value='"+item.url+"' index='"+index+"' "+selected+">"+item.name+"</option>";
}
});
var htmlMould = `
<div style="margin:15px 15px 50px 15px;padding:10px;background-color:`+themeColor+`;border-radius:4px;cursor:pointer;z-index: 999999999999999999999;color:#FFF;">
<div style="font-weight:700;font-size:14px;text-align:center;">
<span>选择解析接口</span>
<select id="interface_selection_`+this.elementId+`" style="background-color:#FFF;padding: 0px 10px;">
`+category_1_html+`
</select>
</div>
<div style="text-align:center;">
<a href="javascript:void(0);" id="start_analysis_outer_`+this.elementId+`" style="box-sizing:border-box;margin:10px 0px;display:inline-block;padding:10px 0px;width:100%;border-radius:4px;color:#FFF;background-color:#F2503F;font-size:14px;">站外解析</a>
</div>
<div style="text-align:left;font-size:10px;">
<div>
免责申明:1、VIP视频解析中所用到的解析接口全部收集自互联网(源码可见),版权问题请联系相关解析接口所有者!
2、为创造良好的创作氛围,请大家支持正版!
3、脚本仅限个人学习交流,切勿用于任何商业等其它用途!
4、继续使用,即表明你已经明确使用脚本可能带来的风险,且愿意自行承担相关风险,对于风险脚本不承担任何责任!
</div>
</div>
</div>
`;
nodeElementObject.after(htmlMould);
resolve("ok");
}, 100);
});
};
this.getPlayObjectBySelect = function(){
var indexString = $("#interface_selection_"+this.elementId).find("option:selected").attr("index");
var index = 0;
if(!!indexString){
index = parseInt(indexString);
}
return this.originalInterfaceList[index];
};
this.runEvent = function(){ //事件运行
const self = this;
//初始化
var playObject = self.getPlayObjectBySelect();
$('#start_analysis_outer_'+self.elementId).attr("href", playObject.url + window.location.href);
$('#start_analysis_outer_'+self.elementId).on('click', function (e) {
if(commonFunctionObject.GMgetValue("copyright_video_remind_mobile_outer",null)==="true"){
}else{
var r=confirm(
"脚本运行提醒!!!\u000d"+
"使用站外解析功能,视频解析时脚本跳出本页面,如不同意此脚本行为,请点击【取消】按钮!!"
);
if(r==false){
e.preventDefault();
}else{
commonFunctionObject.GMsetValue("copyright_video_remind_mobile_outer","true");
}
}
});
//接口切换
$('#interface_selection_'+self.elementId).on('change', function () {
var $option = $(this).find("option:selected");
var value = $option.val();
var index = parseInt($option.attr("index"));
$('#start_analysis_outer_'+self.elementId).attr("href", value+window.location.href);
commonFunctionObject.GMsetValue(self.quicklyInterfaceKey, index);
});
};
this.start = function(){
const self = this;
if(this.isRun()){
this.addHtmlElements().then(()=>{
self.runEvent();
});
}
}
}
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{
var r=confirm(
"脚本运行提醒!!!\u000d"+
"1、VIP视频解析中所用到的解析接口全部收集自互联网(源码可见),版权问题请联系相关解析接口所有者!\u000d"+
"2、为创造良好的创作氛围,请大家支持正版!\u000d"+
"3、脚本仅限个人学习交流,切勿用于任何商业等其它用途!\u000d"+
"4、继续使用,即表明你已经明确使用脚本可能带来的风险,且愿意自行承担相关风险,对于风险脚本不承担任何责任!\u000d"+
"5、此提醒只弹出一次,确认后,后续将不在弹出,请知悉!"
);
if(r==true){
commonFunctionObject.GMsetValue("copyright_video_remind","true");
superVideoHelperObject.start();
}
}
}
(new SuperVideoHelperMobile(newOriginalInterfaceList)).start();
}
}catch(e){
console.log("全网VIP解析:error:"+e);
}
/**
* 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.text("下载视频");
btnElement.removeAttr("disabled");
};
this.downloadResutSuccess=function(btnElement){
btnElement.text("下载视频");
btnElement.removeAttr("disabled");
};
this.getDownloadPages = function(){
return new Promise(function(resolve, reject) {
var pathname = window.location.pathname, bv = null;
if (pathname.indexOf("/medialist/play/watchlater/") != -1) { // 在下载视频的时候针对稍后再看页面的链接找BV号
bv = pathname.replace("/medialist/play/watchlater/","").replace("/","");
}else{
bv = pathname.replace("/video/","").replace("/","");
}
if(!bv){
resolve({"status":"bv_null"});
return;
}
//bv转av
commonFunctionObject.request("get", "https://api.bilibili.com/x/web-interface/view?bvid="+bv, null).then((resultData)=>{
let dataJson = JSON.parse(resultData.data);
if(!dataJson || dataJson.code!==0 || !dataJson.data){
resolve({"status":"request_error"});
return;
}
let data = dataJson.data;
if(!data){
resolve({"status":"aid_null"});
return;
}
let aid = data.aid;
let pic = data.pic;
let title = data.title
if(!aid){
resolve({"status":"aid_null"});
return;
}
//获取cid
commonFunctionObject.request("get", "https://api.bilibili.com/x/web-interface/view?aid="+aid, null).then((resultData2)=>{
let dataJson2 = JSON.parse(resultData2.data);
if(!dataJson2 || dataJson2.code!==0 || !dataJson2.data){
resolve({"status":"request_error"});
return;
}
const downloadData = dataJson2.data;
const {aid, bvid} = downloadData,
items = new Array();
//这是下载集合
if(downloadData.hasOwnProperty("ugc_season") && downloadData.ugc_season.hasOwnProperty("sections")){
let sections = downloadData.ugc_season.sections;
let page = 1;
for(var i=0; i<sections.length; i++){
let section = sections[i];
if(section.hasOwnProperty("episodes")){
for(var j=0; j<section.episodes.length; j++){
let episode = section.episodes[j];
items.push({
"cover":"",
"page":page,
"title":episode.title,
"cid":episode.cid,
"aid":episode.aid
});
page++;
}
}
}
}else{ //这是多P下载
for(var i=0; i<downloadData.pages.length; i++){
let 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); //可能有异常,标题最多50字符
fileName = fileName + ".mp4";
let dataJson3 = JSON.parse(resultData3.data);
if(!!dataJson3 && dataJson3.code===0 && !!dataJson3.data){
let 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(){
var 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;
}
`;
var html = `
<div class='modal-mask-`+this.elementId+`'></div>
<div class='modal-body-`+this.elementId+`'>
<div class="page-header">
<span>视频下载(可批量)</span>
<span class="close">×</span>
</div>
<div class="page-container">
<label style="color:red;">注:此功能会调用bilibili的API,脚本仅用于个人交流,切勿用于商业用途,否则后果自负,特此申明!</label>
<div class="page-wrap">
</div>
<div class="aria2-setting">
<div class="setting-item">
<span><input type="radio" name="downloadWay" value="Motrix">Motrix下载</span>
<span><input type="radio" name="downloadWay" value="AriaNgGUI">AriaNgGUI下载</span>
</div>
<div class="setting-item">
<label class="topic-name">配置RPC:</label><input type="text" name="RPCURL" value="" placeholder="请准确输入RPC对应软件的地址,默认:Motrix">
</div>
<div class="setting-item">
<label class="topic-name">配置Token:</label><input type="text" name="RPCToken" value="" placeholder="默认无需填写">
</div>
<div class="setting-item">
<label class="topic-name">保存路径:</label><input type="text" name="savePath" value="" placeholder="请准确输入文件保存路径">
<div style="font-size:12px;color:#888;">最好自定义下载地址,默认地址可能不满足需要</div>
</div>
</div>
<div class="modal-btn-wrap">
<span name="selectall">全选</span>
<span name="removeSelect">取消选择</span>
<span name="downloadAll">批量下载</span>
</div>
<div class="tip-wrap">
<div class="title">关于单P下载:</div>
<div class="content"><span>点击弹框单个选集,即可下载单集视频!PS:单P下载,推荐大家使用BBDown下载,此工具功能很强大,具体查看:<a target="_blank" href="https://github.com/nilaoda/BBDown">https://github.com/nilaoda/BBDown</a></span></div>
</div>
<div class="tip-wrap">
<div class="title">关于批量下载:</div>
<div class="content">
<ul>
<li>
<b>1、批量下载需要第三方软件的支持,脚本推荐使用:Motrix</b>
<ul>
<li>Motrix下载地址:<a href="https://motrix.app/zh-CN/" target="_blank">https://motrix.app/zh-CN/</a></li>
<li>AriaNgGUI下载地址:<a href="https://github.com/Xmader/aria-ng-gui" target="_blank">https://github.com/Xmader/aria-ng-gui</a></li>
</ul>
</li>
<li>
<b>2、在批量下载前需要提前打开软件,本教程以Motrix为准</b>
<ul>
<li>(1)、如果全部按照默认配置,只需要打开软件即可</li>
<li>(2)、如果想自定义RPC地址和文件保存路径,可更改上面输入框的内容(此数据非常重要,请准确填写)</li>
<li>
(3)、Motrix运行图片
<img src="https://pic.rmb.bdstatic.com/bjh/8912582c0416119405ec37ea27d12376.jpeg" width="100%" />
</li>
</ui>
</li>
<li>
<b>3、默认RPC默认地址</b>
<ul>
<li>(1)、Motrix RPC默认地址:ws://localhost:16800/jsonrpc</li>
<li>(2)、Aria2 RPC默认地址:ws://localhost:6800/jsonrpc</li>
<li>(3)点击“批量下载会自动保存当前下载设置”</li>
</ul>
</li>
<li>
<b>4、如使用AriaNgGUI,使用方式类似,大家可以自行研究</b>
</li>
</ul>
</div>
</div>
<div class="tip-wrap">
<div class="title">必要说明:</div>
<div class="content">
申明:本功能仅能作为学习交流使用,且不可用于其它用途,否则后果自负。请大家重视版权,尊重创作者,切勿搬运抄袭。请大家多用[一键三连]为创作者投币~,小破站牛掰!
</div>
</div>
</div>
</div>
`;
commonFunctionObject.GMaddStyle(css);
$("body").append(html);
};
this.hideModals = function(){
$(".modal-body-"+this.elementId+"").css('display','none');
$(".modal-mask-"+this.elementId+"").css('display','none');
};
this.showModals = function(pageHtml){
const self = this;
const downloadSettingKey = self.downloadSettingKey;
$(".modal-body-"+self.elementId+"").css('display','block');
$(".modal-mask-"+self.elementId+"").css('display','block');
$(".modal-body-"+self.elementId+" .page-wrap").html(pageHtml);
//初始化设置的数据
var 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";
$(".modal-body-"+self.elementId+" input[name='RPCURL']").val(downloadSetting.RPCURL);
$(".modal-body-"+self.elementId+" input[name='savePath']").val(downloadSetting.savePath);
$(".modal-body-"+self.elementId+" input[name='RPCToken']").val(downloadSetting.RPCToken);
$(".modal-body-"+self.elementId+" input[name='downloadWay']").removeAttr("checked");
if(isMotrix){
$(".modal-body-"+self.elementId+" input:radio[value='Motrix']").attr('checked','true');
}else{
$(".modal-body-"+self.elementId+" input:radio[value='AriaNgGUI']").attr('checked','true');
}
$(".modal-body-"+self.elementId+" .page-wrap >.board-item >span").off("click").on("click", function(){
$(this).css("background-color","#ccc");
let downloadOptions={
"aid":$(this).data("aid"),
"cid":$(this).data("cid"),
"isByPRC":false
}
self.startDownloadFile(downloadOptions);
});
$(".modal-body-"+self.elementId+" .page-header >span.close").off("click").on("click", function(){
self.hideModals();
});
$(".modal-body-"+self.elementId+" .modal-btn-wrap >span[name='selectall']").off("click").on("click", function(){
$(".modal-body-"+self.elementId+" .page-wrap").find("input[type='checkbox']").each(function(){
$(this).prop('checked', true);
});
});
$(".modal-body-"+self.elementId+" input[name='downloadWay']").off("change").on("change", function(){
if($(this).val()=="Motrix"){
$(".modal-body-"+self.elementId+" input[name='RPCURL']").val("ws://localhost:16800/jsonrpc");
}else{
$(".modal-body-"+self.elementId+" input[name='RPCURL']").val("ws://localhost:6800/jsonrpc");
}
});
$(".modal-body-"+self.elementId+" .modal-btn-wrap >span[name='removeSelect']").off("click").on("click", function(){
$(".modal-body-"+self.elementId+" .page-wrap").find("input[type='checkbox']").each(function(){
$(this).prop('checked', false);
});
});
$(".modal-body-"+self.elementId+" .modal-btn-wrap >span[name='downloadAll']").off("click").on("click", function(){
let RPCURL = $(".modal-body-"+self.elementId+" input[name='RPCURL']").val();
let savePath = $(".modal-body-"+self.elementId+" input[name='savePath']").val();
let RPCToken = $(".modal-body-"+self.elementId+" input[name='RPCToken']").val();
let downloadWay = $(".modal-body-"+self.elementId+" input[name='downloadWay']:checked").val();
commonFunctionObject.GMsetValue(downloadSettingKey,{"RPCURL":RPCURL, "savePath":savePath,
"RPCToken":RPCToken, "downloadWay":downloadWay});
let inputElements = $(".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;
}
RPCToken = !RPCToken ? "" : RPCToken;
let downloadOptions = {
"aid":"",
"cid":"",
"isByPRC":true,
"fileName":"",
"savePath":savePath,
"RPCURL":RPCURL,
"RPCToken":RPCToken
}
inputElements.each(function(){
setTimeout(()=>{
let aid=$(this).data("aid"), cid = $(this).data("cid"), fileName = $(this).attr("title");
downloadOptions.aid = aid;
downloadOptions.cid = cid;
downloadOptions.fileName = fileName;
self.startDownloadFile(downloadOptions);
}, 1000);
})
});
};
this.createElementHtml = async function(){
$("#bilibili_exti_9787fjfh12j").remove();
const randomNumber = this.elementId, self = this;
let 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;
}
`;
let htmlText=`
<div id="bilibili_exti_9787fjfh12j">
<div class="self_s_btn" id="download_s_`+randomNumber+`">下载视频</div>
<div class="self_s_btn" id="focus_s_`+randomNumber+`">一键三连</div>
</div>
`;
//添加下载等操作按钮
commonFunctionObject.GMaddStyle(cssText);
$("body").append(htmlText);
//创建弹框
this.createModals();
//移入移除操作
$("#bilibili_exti_9787fjfh12j").hover(function(){
$(this).css({
"left":"0px", "opacity":1
});
},function(){
$(this).css({
"left":(0-$(this).width())/2+"px", "opacity":0.6
});
});
//下载操作函数
$("body").on("click", "#download_s_"+randomNumber, function(){
const btnElement = $(this);
btnElement.attr("disabled", "disabled");
btnElement.text("准备中~");
//开始准备下载数据
self.getDownloadPages().then((resule)=>{
if(resule.status==="success"){
const {items, pic, title} = resule.downloadData;
let itemHtml = "";
itemHtml += "<div style='width:100%;'><a href='"+pic+"' target='_blank'>标题:"+title+"(点我跳转封面)</a></div>";
for(var i=0; i<items.length; i++){
var currentTitle = "【P"+items[i].page+"】"+items[i].title+"";
itemHtml += "<div class='board-item'>";
itemHtml += "<input data-aid='"+items[i].aid+"' data-cid='"+items[i].cid+"' title='"+currentTitle+"' type='checkbox'>"
itemHtml += "<span data-aid='"+items[i].aid+"' data-cid='"+items[i].cid+"' title='"+currentTitle+"'>"+currentTitle+"</span>";
itemHtml += "</div>";
}
self.showModals(itemHtml);
self.downloadResutSuccess(btnElement);
}else{
self.downloadResutError(btnElement);
}
}).catch((error)=>{
self.downloadResutError(btnElement);
});
});
$("body").on("click", "#focus_s_"+randomNumber, function(){
$("#arc_toolbar_report .video-like").click(); // 点赞
$("#arc_toolbar_report .video-coin").click(); // 投币
// $("#arc_toolbar_report .video-fav").click(); // 收藏
});
}
this.start = function(){
let locationHost = window.location.host, locationPathname = window.location.pathname;
if(locationHost==="www.bilibili.com" && (locationPathname.indexOf("/video")!=-1 || locationPathname.indexOf("/watchlater")!=-1)){
this.createElementHtml();
}
}
}
try{
(new baseFunctionObject()).start();
}catch(e){
console.log("baseFunctionObject new error", e);
}
};
/**
* 浏览历史记录提醒
*/
this.recordViewFunction = function(){
function recordViewObject(){
this.localCacheName = "bilibili_video_record";
this.recordOneVideo = function(){
let promise = new Promise((resolve, reject)=>{
let bv = commonFunctionObject.getBilibiliBV();
let cacheText = commonFunctionObject.GMgetValue(this.localCacheName);
cacheText = !cacheText ? "" : cacheText
let maxLength = 12*500;
let currentLength = cacheText.length;
if(currentLength > maxLength){
cacheText = cacheText.substring(12*100, currentLength);
}
if(cacheText.indexOf(bv)==-1){
cacheText += bv;
commonFunctionObject.GMsetValue(this.localCacheName, cacheText);
}
resolve({"result":"success"});
});
};
this.searchPageRemindHtml = function($ele, top=8, right=8){
if($ele.find("div[name='marklooked']").length==0){
$ele.css("position","relative");
$ele.append("<div name='marklooked' style='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>");
}
};
this.searchPageRemind = function(){
let $that = this;
var elementArray = [
{"node":".bili-video-card", "top":8, "right":12}, //兼容 MAC M1搜索结果
{"node":"#page-index .small-item", "top":12, "right":12}, //用户投稿
{"node":"#submit-video-list .small-item", "top":12, "right":12}, //用户主页
{"node":"#page-series-detail .small-item.fakeDanmu-item", "top":12, "right":12}, //用户主页投稿
];
setInterval(function(){
let cacheText = commonFunctionObject.GMgetValue($that.localCacheName);
cacheText = !cacheText ? "" : cacheText;
for(var i=0; i<elementArray.length; i++){
var elementobj = elementArray[i];
$(elementobj.node).each(function(){
if($(this).attr("dealxll")!=="true"){
var videourl = $(this).find("a[href^='//www.bilibili.com/video']").attr("href");
if(!!videourl){
var bvs = videourl.match(/(\/BV(.*?)\/)/g)
if(bvs.length==1){
var bv = bvs[0].replace(/\//g,"");
if(cacheText.indexOf(bv) != -1){
$that.searchPageRemindHtml($(this), elementobj.top, elementobj.right);
}
$(this).unbind("click").bind("click", ()=>{ //循环操作,单独绑定
$that.searchPageRemindHtml($(this), elementobj.top, elementobj.right);
})
}
$(this).attr("dealxll","true");
}
}
});
}
}, 500);
}
this.start=function(){
let $that = this;
if(window.location.pathname.indexOf("/video")!=-1 && window.location.host==="www.bilibili.com"){
let currentHref = "";
setInterval(()=>{ //需要循环存储
if(window.location.href !== currentHref){
this.recordOneVideo();
currentHref = window.location.href;
}
}, 500);
}
//搜索结果和用户主页已经看过的视频提醒
if(window.location.host.indexOf("bilibili.com")!=-1){
this.searchPageRemind();
GM_registerMenuCommand("清空B站浏览记录",function(){
if(confirm('是否要清空B站浏览记录?清空后将不可恢复...')){
commonFunctionObject.GMsetValue($that.localCacheName, "");
}
});
}
};
}
try{
(new recordViewObject()).start();
}catch(e){
console.log("recordViewObject new error", e);
}
};
/**
* 视频描述文本转链接
*/
this.textToLinkFunction = function() {
function textToLinkObject(){
this.link = function(selector){
const current_href = window.location.href;
const textToLinkArea = document.querySelector(selector);
if(!textToLinkArea){
return;
}
findAndReplaceDOMText(textToLinkArea, {
find: /(http|ftp|https):\/\/[\w\-_]+(\.[\w\-_]+)+([\w\-\.,@?^=%&:/~\+#]*[\w\-\@?^=%&/~\+#])?/g,
replace: function (e, t) {
let 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(){ //签到下线,2024年7月2日
}
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(){
var 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(){
var regexResult = location.search.match(/target=(.+?)(&|$)/);
if(regexResult && regexResult.length==3){
location.href = decodeURIComponent(regexResult[1]);
}
};
// 为问题本身添加时间
this.addDateQuestion = function(){
var title = document.querySelector(".QuestionPage");
if(!!title){
var dateCreated = title.querySelector("[itemprop~=dateCreated][content]").content;
var dateModified = title.querySelector("[itemprop~=dateModified][content]").content;
var createDate = commonFunctionObject.DateFormat(new Date(dateCreated), "yyyy-MM-dd hh:mm:ss");
var editDate = commonFunctionObject.DateFormat(new Date(dateModified), "yyyy-MM-dd hh:mm:ss");
var side = title.querySelector(".QuestionHeader-side");
var timeDiv = document.createElement('div');
timeDiv.innerHTML = `<p>创建于: ${createDate}</p><p>编辑于: ${editDate}</p>`;
timeDiv.style.cssText = 'color:#6f6f6f;font-size:13px;';
side.appendChild(timeDiv);
}
};
// 为回答添加时间
this.addTimeAnswerItems = function(){
var list = document.querySelectorAll(".AnswerItem:not(div[zh_date_mk='true'])");
var item = null;
for (var i = 0; i < list.length; i++) {
item = list[i];
if (item.getAttribute('zh_date_mk') === 'true') {
continue;
}
item.setAttribute("zh_date_mk", "true");
try{
var dateCreated = item.querySelector("[itemprop~=dateCreated][content]").content;
var dateModified = item.querySelector("[itemprop~=dateModified][content]").content;
var createDate = commonFunctionObject.DateFormat(new Date(dateCreated), "yyyy-MM-dd hh:mm:ss");
var editDate = commonFunctionObject.DateFormat(new Date(dateModified), "yyyy-MM-dd hh:mm:ss");
var sideItem = item.querySelector(".ContentItem-meta");
var timeDiv = document.createElement('div');
timeDiv.innerHTML = `创建于: ${createDate} 修改于: ${editDate}`;
timeDiv.class = "Voters";
timeDiv.style.cssText = 'color:#6f6f6f;font-size:13px;display:block;padding:5px 0px;';
sideItem.appendChild(timeDiv);
}catch(e){}
}
return true;
};
// 提问者标识出来
this.showQuestionAuthor = function(){
//此处代码借鉴自 - 知乎增强
//原作者:X.I.U
//https://greasyfork.org/zh-CN/scripts/419081-%E7%9F%A5%E4%B9%8E%E5%A2%9E%E5%BC%BA
if (document.querySelector('.BrandQuestionSymbol, .QuestionAuthor')) return
let qJson = JSON.parse(document.querySelector('#js-initialData').textContent).initialState.entities.questions[/\d+/.exec(location.pathname)[0]].author,
html = `<div class="BrandQuestionSymbol"><a class="BrandQuestionSymbol-brandLink" href="/people/${qJson.urlToken}"><img role="presentation" src="${qJson.avatarUrl}" class="BrandQuestionSymbol-logo" alt=""><span class="BrandQuestionSymbol-name">${qJson.name}</span></a><div class="BrandQuestionSymbol-divider" style="margin-left: 5px;margin-right: 10px;"></div></div>`;
document.querySelector('.QuestionHeader-topics').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;
var itemArray = document.querySelectorAll("._1tg8oir:not(span[zh_date_mk='true'])");
var item = null;
// console.log("知乎视频下载循坏监听次数:", itemArray.length);
for(var i=0; i<itemArray.length; i++){
item = itemArray[i];
if (item.getAttribute('zh_date_mk') === 'true') {
continue;
}
item.setAttribute("zh_date_mk", "true");
if(item.innerText != "倍速"){
continue;
}
var playButLi = item.parentNode.parentNode;
var downloadBut = playButLi.cloneNode(true)
if(!downloadBut.querySelector('._1tg8oir')) return;
// 删除其它元素
var downloadButChildren = downloadBut.children;
for(var 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(){
let href = window.location.href;
let findClassName = ".ZVideoItem-video"; // 首页
if(href.indexOf("www.zhihu.com/search")!=-1){ //搜索界面
findClassName = ".List-item";
}else if(href.indexOf("www.zhihu.com/zvideo/")!=-1){ //单独视频播放界面
findClassName = ".ZVideo-player";
}else if(href.indexOf("https://video.zhihu.com/video")!=-1){ //视频播放iframe
findClassName = "#player"
}
if(!findClassName) return;
let playUrl = $(item).parents(findClassName).find("video").attr("src");
if(!!playUrl){
commonFunctionObject.GMopenInTab(playUrl);
}
});
}
isMarkComplete = true;
}
setInterval(()=>{
addDownloadButton();
}, 1499);
};
this.start = function(){
const host = window.location.host;
const self = this;
if(host == "link.zhihu.com"){
this.autoJumpTarget();
}
if(host.indexOf("zhihu.com")!=-1){
this.markArticleOrQuestion();
if(window.location.href.indexOf("www.zhihu.com/question/")!=-1){
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{
let customNavigationData = commonFunctionObject.GMgetValue(self.customNavigationkey, null); //自定义的数据
if(!!customNavigationData){
finalNavigationData = [].concat(customNavigationData);
// console.log("使用本地");
}else{
let currentMS = (new Date()).getTime();
let delayMS = 1000 * 60 * 5;
let 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)=>{
let data = JSON.parse(serverJson.data); //获取本地data
data.ms = currentMS; //添加时间戳保存到本地区
commonFunctionObject.GMsetValue(self.serverNavigationkey, data);
//console.log("拉取服务器");
}).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){
var 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;
font-weight: 500;
background: rgba(49, 94, 251, 0.1);
}
.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;
}
`;
if($("#plugin_css_style_dddsoo").length==0){
$("body").prepend("<style id='plugin_css_style_dddsoo'>"+innnerCss+"</style>");
}
};
this.showSetingDialog = function(){
const self = this;
var customNavigationData = "";
const customNavigation = commonFunctionObject.GMgetValue(self.customNavigationkey, null);
if(!!customNavigation){
customNavigationData = JSON.stringify(customNavigation, null, 4);
}
const content = `
<div>
<div style="font-size:13px;color:red;">
注意事项如下:
<br>1、请严格按照格式添加,否则不生效
<br>2、数据为json格式,请确保json格式正确,必要时请到<a target="_blank" href="https://www.json.cn/">https://www.json.cn/</a>校验
<br>3、点击下面”示例“按钮,查看具体格式情况
<br>4、链接中的搜索关键词请用”@@“代替,脚本会自动替换成当前搜索词。例如:https://www.baidu.com/s?wd=@@
<br>5、大家可以自定义导航数据,<b>但是必须要注意数据格式,发现出现错误,可点“初始化”</b>
</div>
<div style="margin-top:5px;height:200px;width:100%;">
<textarea
placeholder="请严格按照格式填写,否则不生效"
class="navigation-textarea"
style="color:#000;font-size:14px;box-sizing: border-box;-webkit-box-sizing: border-box;-moz-box-sizing: border-box;padding:5px;height:100%;width:100%;Overflow:auto;border:1px solid #ccc;resize:none;background-color:#FFF;outline:none;">`+customNavigationData+`</textarea>
</div>
<div style="text-align:center;margin-top:15px;">
<button class="navigation-init" style="color:#000;cursor:pointer;">初始化</button>
<button class="navigation-example" style="color:#000;cursor:pointer;">示例</button>
<button class="navigation-clear" style="color:#000;cursor:pointer;">清空</button>
<button class="navigation-save" style="color:#000;cursor:pointer;">保存自定义导航</button>
</div>
</div>
`;
dialog.showMake({
"title":"自定义添加导航",
"content":content,
"onClose":function(){
location.reload();
},
"onContentReady":function($that){
var $navigationExample = $that.dialogContent.querySelector(".navigation-example");
var $navigationClear = $that.dialogContent.querySelector(".navigation-clear");
var $navigationSave = $that.dialogContent.querySelector(".navigation-save");
var $navigationInit = $that.dialogContent.querySelector(".navigation-init");
var $textarea = $that.dialogContent.querySelector(".navigation-textarea");
$navigationExample.addEventListener("click", function(){
$textarea.value = JSON.stringify(self.defaultNavigationData, null, 4);
});
$navigationClear.addEventListener("click", function(){
$textarea.value = "";
});
$navigationInit.addEventListener("click", function(){
$textarea.value = "";
commonFunctionObject.GMsetValue(self.customNavigationkey, null);
});
$navigationSave.addEventListener("click", function(){
var 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{
var contentJson = JSON.parse(content);
if(Array.isArray(contentJson)){ //开始必须是数组
var isOK = true;
for(var 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(var 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){
$("#dsdsd99mmmjj7760011").remove();
var isComplate = true;
const host = window.location.host;
const self = this;
const elementNum = commonFunctionObject.randomNumber();
const elementInterval = setInterval(function(){
if(isComplate){
var $element = $(element);
var $box = $("#dsdsd99mmmjj7760011");
isComplate = false;
if($element.length!=0 && $box.length==0){
var nameArray = [];
var linkArray = [];
for(var i=0; i<navigationData.length; i++){
var name = "";
if(i==0){
name += '<span class="tabs-t'+elementNum+' tabs-t-selected-ddsds1idddx90" name="tab-list-xxsddddssd-'+i+'">'+navigationData[i].name+'</span>';
}else{
name += '<span class="tabs-t'+elementNum+' tabs-t-small-ddsds1idddx90" name="tab-list-xxsddddssd-'+i+'">'+navigationData[i].name+'</span>';
}
nameArray.push(name);
var links = "";
if(i==0){
links = '<div id="tab-list-xxsddddssd-'+i+'">';
}else{
links = '<div id="tab-list-xxsddddssd-'+i+'" style="display:none;">';
}
for(var j=0;j<navigationData[i].list.length;j++){
let url = navigationData[i].list[j].url;
url = url.replace("${t}",(new Date()).getTime());
let name = navigationData[i].list[j].name;
links += "<a target='_blank' name='navigation' data-url='"+url+"' href='javascript:void(0);'>"+name+"</a>"
}
links += "</div>";
linkArray.push(links);
}
var html = `
<div id="dsdsd99mmmjj7760011">
<div class="tab`+elementNum+`">
<div class="tab-c-titles`+elementNum+`">`+nameArray.join("")+`</div>
<div class="tab-c-links`+elementNum+`">`+linkArray.join("")+`</div>
</div>
<div style='margin-bottom:10px;margin-top:5px;font-size:12px;'>
<a target='_blank' href='https://scriptcat.org/zh-CN/script-show-page/509' style="color: #000;background-color: #efefef;padding: 2px 5px; border-radius: 2px;">*该数据由油猴脚本提供</a>
<a href="javascript:void(0);" name="customNavigation" style="color: #000;background-color: #efefef;padding: 2px 5px; border-radius: 2px;">🔧自定义网址</a>
</div>
<div>
`;
// //添加css 添加html
self.createCss(elementNum);
$element.prepend(html);
//点击切换tab
$("#dsdsd99mmmjj7760011 .tabs-t"+elementNum).on("click", function(e){
$("div[id^='tab-list-xxsddddssd-']").hide();
$(".tabs-t"+elementNum).removeClass("tabs-t-selected-ddsds1idddx90");
$("#"+$(this).attr("name")).show();
$(this).addClass("tabs-t-selected-ddsds1idddx90");
});
//点击链接
$("#dsdsd99mmmjj7760011 a[name='navigation']").on("click", function(e){
commonFunctionObject.GMopenInTab($(this).data("url").replace("@@",$(elementInput).val()));
e.preventDefault()
});
//弹出自定义导航弹窗
$("#dsdsd99mmmjj7760011 a[name='customNavigation']").on("click", function(e){
self.showSetingDialog();
e.preventDefault()
});
}
isComplate = true;
}
}, 100);
};
this.hookBaidu = function(){
let items = document.querySelectorAll("#content_left>div");
for(let item of items){
//给处理完成的做一个标识
if(!!item.getAttribute("baidu_dealxx")){
continue;
}
item.setAttribute("baidu_dealxx","--");
let a = item.querySelector("a");
if(!a || !a.href){
continue;
}
//标注了html网址的忽略
let OP_LOG_LINK = item.querySelector(".OP_LOG_LINK");
if(!!OP_LOG_LINK && OP_LOG_LINK.innerText.search("http")!=-1){
continue;
}
//有多个点击点的忽略
let cGapBottomSmall = item.querySelector(".c-gap-bottom-small");
if(!!cGapBottomSmall){
continue;
}
//https://www.baidu.com/s?wd=一夜醒来欠地铁600多万?官方回应
if (a.href.includes("www.baidu.com/link?url=")) {
let url = item.getAttribute("mu");
if (url && url != null && !url.includes("nourl.ubs.baidu.com")) {
a.href = url;
item.innerHTML += `<div style="color:#ccc;font-size:12px;display:flex;align-items:center;width:100%;overflow:hidden;white-space: nowrap;text-overflow: ellipsis;-o-text-overflow:ellipsis;">
<img style="width:15px;height:15px;" src=""/>
<a style="color:#626675;" href="`+url+`" target="_blank">`+url+`</a>
</div>`;
}
}
let itemNews = item.querySelectorAll("[class^=single-card-wrapper] div,[class^=group-wrapper] div");
if(!itemNews){
continue;
}
//single-card-wrapper: https://www.baidu.com/s?ie=UTF-8&wd=es6 xxx的最新相关信息
//group-wrapper: https://www.baidu.com/s?ie=UTF-8&wd=五一消费成绩单折射市场活力 资讯
for(let itemNew of itemNews){
let dataUrl = null;
let divs = itemNew.querySelectorAll("div");
for (let div of divs) {
if ((dataUrl = div.getAttribute("data-url"))) {
let a = itemNew.querySelector("a");
a.setAttribute("href", dataUrl);
}
}
}
}
};
this.hookGoogle = function(){
let 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 href = window.location.href;
const search = window.location.search;
const self = this;
setInterval(function(){
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;
if((host==="www.baidu.com")
|| (host==="www.so.com" && href.indexOf("www.so.com/s")!=-1)
|| (host==="www.sogou.com" && (href.indexOf("www.sogou.com/web")!=-1 || href.indexOf("www.sogou.com/sogou")!=-1))
|| (host==="cn.bing.com" && href.indexOf("cn.bing.com/search")!=-1)
|| (host==="www.bing.com" && href.indexOf("www.bing.com/search")!=-1)
|| (host==="www4.bing.com" && href.indexOf("www4.bing.com/search")!=-1)
|| (host==="so.toutiao.com" && href.indexOf("so.toutiao.com/search")!=-1)
|| (host==="www.google.com" && href.indexOf("www.google.com/search")!=-1)
|| (host==="www.google.com.hk" && href.indexOf("www.google.com.hk/search")!=-1)
|| (host==="duckduckgo.com" && href.indexOf("duckduckgo.com")!=-1)){
let currentSearchEnginesData = null;
for(var i=0; i<self.searchEnginesData.length; i++){
if(host===self.searchEnginesData[i].host){
currentSearchEnginesData = self.searchEnginesData[i];
}
}
if(currentSearchEnginesData!=null){
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= `
<div style="position:absolute;white-space: nowrap; top:7px;padding:2px 5px;font-size:12px;background-color:rgba(0,0,0);color:#FFF;z-index:9999999999;border-radius:20px;right:10px;"><b>已浏览</b></div>
`
function HistoryObject(){
this.redirectUrl="https://j.jiayoushichang.com/api/go/to?e=";
this.storageKeys={
goodsHistory:"goooods_history_key",
offset:"goooods_wrapper_key",
maximumRecordsKey:"goooods_max_records_key"
};
this.defaultValue={
historyStorage:{"jd":[], "taobao":[], "vpinhui":[]},
offsetWrapper:{left:15, bottom:15},
records:{min:10, max:500, default:100}
};
this.push=function(platform, obj){
const storageObj = GM_getValue(this.storageKeys.goodsHistory, this.defaultValue.historyStorage);
const maximumRecords = GM_getValue(this.storageKeys.maximumRecordsKey, this.defaultValue.records.default);
const histories = storageObj[platform] ?? [];
if(histories.length>=maximumRecords){
histories.splice(0, parseInt(maximumRecords/5)); //removev forward 1/5
}
const newArr = histories.filter((item, index) => item.id != obj.id);
newArr.push(obj);
storageObj[platform] = newArr;
GM_setValue(this.storageKeys.goodsHistory, storageObj);
};
this.get=function(platform, num=-1){
const storageObj = GM_getValue(this.storageKeys.goodsHistory, this.defaultValue.historyStorage);
const histories = storageObj[platform];
if(num > 0){ // <0 is get all storage
const showHistories = [];
for(let i=histories.length-1; i>=0; i--){
if(showHistories.length>=num) break;
showHistories.push(histories[i]);
}
return showHistories;
}
return histories;
};
this.remove=function(platform, id){
const storageObj = GM_getValue(this.storageKeys.goodsHistory, this.defaultValue.historyStorage);
const histories = storageObj[platform];
let newArr = histories.filter((item, index) => item.id != id);
storageObj[platform] = newArr;
GM_setValue(this.storageKeys.goodsHistory, storageObj);
};
this.removeAll=function(){
GM_setValue(this.storageKeys.goodsHistory, this.defaultValue.historyStorage);
document.querySelector(".peter99032j-xyz-panel-aside-body .goods_____review").innerHTML='';
document.querySelector(".peter99032j-xyz-panel-aside-main .panel-aside-main_____content").innerHTML='';
};
this.removeAllConfirm=function(){
if(confirm('此弹窗来自脚本-[🔥]!!网购小助手,不花冤枉钱\n是否要移除所有的浏览记录?移除后将不可恢复...')){
this.removeAll(); //box展示
commonFunctionObject.GMsetValue(recordBrowsingHistoryKey,[]); //已浏览标识
}
};
this.registerMenuCommand=function(){
GM_registerMenuCommand("浏览记录设置【点击或shift+c均可可唤起】", ()=> {
this.showSettingDialog();
});
const listener = new window.keypress.Listener();
listener.simple_combo("shift c", ()=>{
this.showSettingDialog();
});
};
this.getGoodsByDateGroup=function(platform){
const histories = this.get(platform).reverse();
const group = [];
const today = new Date();
const yesterday = new Date(today);
const format = "dd/MM";
yesterday.setDate(today.getDate() - 1);
const todayStr = this.dateFormat(today, format);
const yesterdayStr = this.dateFormat(yesterday, format);
const showDateFormat = (todayStr, yesterdayStr, current) =>{
return current === todayStr ? "今天" : (current === yesterdayStr ? "昨天" : current);
};
let items = [], cacheDateStr=null, currentDateStr = null;
for(let i=0; i<histories.length; i++){
today.setTime(histories[i].date);
currentDateStr = this.dateFormat(today, format);
if(!!cacheDateStr){
if(cacheDateStr != currentDateStr){
group.push({
"str":showDateFormat(todayStr, yesterdayStr, cacheDateStr),
"items":items
});
items = [];
cacheDateStr = currentDateStr;
}
}else{
cacheDateStr = currentDateStr;
}
items.push(histories[i]);
}
if(items.length!=0){
group.push({
"str":showDateFormat(todayStr, yesterdayStr, cacheDateStr),
"items":items
});
}
return group;
};
this.dateFormat=function(date,format){
var showDate = {
"M+": date.getMonth() + 1,
"d+": date.getDate(),
"h+": date.getHours(),
"m+": date.getMinutes(),
"s+": date.getSeconds(),
"q+": Math.floor((date.getMonth() + 3) / 3),
"S+": date.getMilliseconds()
};
if (/(y+)/i.test(format)) {
format = format.replace(RegExp.$1, (date.getFullYear() + '').substr(4 - RegExp.$1.length));
}
for (var k in showDate) {
if (new RegExp("(" + k + ")").test(format)) {
format = format.replace(RegExp.$1, RegExp.$1.length == 1
? showDate[k] : ("00" + showDate[k]).substr(("" + showDate[k]).length));
}
}
return format;
};
this.showSettingDialog=function(){
const outerId = "dialog_x_" + Math.ceil(Math.random()*100000000);
const self = this;
const {min,max} = this.defaultValue.records;
const maximumRecords = GM_getValue(this.storageKeys.maximumRecordsKey, this.defaultValue.records.default);
const styleSheet = `
#`+outerId+`{
padding:15px;
}
#`+outerId+` .d_____piece{
margin-bottom:15px;
font-size:15px;
}
#`+outerId+` .d_____input{
padding: 5px 10px !important;
background-color: #fafafa !important;
color: #000 !important;
border: 1px solid #ccc !important;
font-size: 14px !important;
border-radius: 4px !important;
width: 80px !important;
text-align: center !important;
}
#`+outerId+` .d_____btn{
padding: 4px 15px !important;
background-color: #edf2fa !important;
color: #000 !important;
border-radius: 4px!important;
font-size: 14px!important;
border:none!important;
}
#`+outerId+` .d_____btn:hover{
background-color: #cdd1da !important;
}
`;
var tips = "最大浏览记录数(最小: {min},最大:{max},改变的值会自动保存):";
tips = tips.replace("{min}", min);
tips = tips.replace("{max}", max);
const content = `
<div id="`+outerId+`">
<div class="d_____piece">
`+tips+`<input class="d_____input" number="number" min="`+min+`" max="`+max+`" step="1" value="`+maximumRecords+`" name="maximum-records"/>
</div>
<div class="d_____piece">
<p>清除所有浏览浏览记录。注意:清除后浏览记录不可恢复,请谨慎操作。</p>
<button class="d_____btn" name="clear">清除</button>
</div>
</div>
`;
dialog.showMake({
title: "设置",
content: content,
styleSheet: styleSheet,
onContentReady:function($that){
$that.dialogContent.querySelector("button[name='clear']").addEventListener("click",function(){
self.removeAllConfirm();
});
$that.dialogContent.querySelector("input[name='maximum-records']").onchange=function(e){
const value = this.value;
if(value>=min && value<=max){
GM_setValue(self.storageKeys.maximumRecordsKey, value);
}
}
}
});
};
this.showOrHideHistoryBox=function(platform){
const self = this;
const group = this.getGoodsByDateGroup(platform);
const contentElement = document.querySelector(".peter99032j-xyz-panel-aside-main .panel-aside-main_____content");
contentElement.innerHTML = "";
let historiesBoxHtml = "", jumpUrl="", imgUrl="";
for(let i=0; i<group.length; i++){
historiesBoxHtml += `<div class="panel-aside-main_____item">`;
historiesBoxHtml += `<div class="item_____title"> —— `+group[i].str+` —— </div>`;
historiesBoxHtml += `<div class="item_____container">`;
for(let j=0; j<group[i].items.length; j++){
jumpUrl = commonFunctionObject.encryptStr(this.redirectUrl+encodeURIComponent(group[i].items[j].url));
imgUrl = group[i].items[j].pic;
historiesBoxHtml += `
<div class="histories-box-review_item">
<a title="`+group[i].items[j].title+`" jump-tag="true" href="javascript:void(0);" jump-url="`+jumpUrl+`" target="_blank">
<div class="review___shadow">
<div class="delete_____btn" data-id="`+group[i].items[j].id+`">×</div>
</div>
<div class="review___img"><img src="`+imgUrl+`" /></div>
<div class="review___text">¥`+group[i].items[j].price+`</div>
</a>
</div>
`;
}
historiesBoxHtml += `</div>`;
historiesBoxHtml += `</div>`;
}
contentElement.innerHTML = historiesBoxHtml;
document.querySelectorAll(".peter99032j-xyz-panel-aside-main .delete_____btn").forEach((ele)=>{
ele.addEventListener("click",function(e){
e.stopPropagation();
e.preventDefault();
const id = this.getAttribute("data-id");
this.parentNode.parentNode.parentNode.remove();
self.remove(platform, id);
});
});
const items = document.querySelectorAll(".peter99032j-xyz-panel-aside-main .histories-box-review_item > a");
items.forEach((ele)=>{
ele.addEventListener('mouseover', function() {
this.querySelector(".review___shadow").style.display="block";
});
ele.addEventListener('mouseout', function() {
this.querySelector(".review___shadow").style.display="none";
});
});
document.querySelectorAll(".peter99032j-xyz-panel-aside-main a[jump-tag='true']").forEach((ele)=>{
ele.addEventListener("click",function(e){
e.stopPropagation();
e.preventDefault();
const href = this.getAttribute("jump-url");
commonFunctionObject.GMopenInTab(commonFunctionObject.decryptStr(href));
});
});
};
this.createHistoryBox=function(platform){
const wrapperOffset = GM_getValue(this.storageKeys.offset, this.defaultValue.offsetWrapper);
let css = `
.peter99032j-xyz-panel-wrapper{
position: fixed;
bottom: `+wrapperOffset.bottom+`px;
left: `+wrapperOffset.left+`px;
z-index: 999999999;
box-sizing: border-box;
}
.peter99032j-xyz-panel-wrapper svg.icon-svg path{
fill: #bfbfbf;
}
.peter99032j-xyz-panel-wrapper svg.icon-svg:hover path{
fill: #6a7a9b;
}
/*** 历史记录大box ***/
.peter99032j-xyz-panel-wrapper >.peter99032j-xyz-panel-aside-main{
width: 400px;
height: 400px;
position: absolute;
left: 0px;
bottom: 70px;
border-radius: 5px;
border: 1px solid #ebebeb;
background-color: #fafafa;
overflow-y: auto;
overflow-x: hidden;
background-color:#fafafa;
display:none;
-moz-box-shadow:2px 2px 5px #b6bdc5;
-webkit-box-shadow:2px 2px 5px #b6bdc5;
box-shadow:2px 2px 5px #b6bdc5;
}
.peter99032j-xyz-panel-wrapper >.peter99032j-xyz-panel-aside-main >.panel-aside-main_____inner{
display: flex;
flex-direction: column;
width: 100%;
height: 100%;
}
.peter99032j-xyz-panel-aside-main .panel-aside-main_____header{
display: flex;
align-items: center;
flex-direction: row;
height:40px;
background: #dedede;
}
.peter99032j-xyz-panel-aside-main .panel-aside-main_____header >.header_____title{
align-items: center;
display: flex;
flex: 1;
margin-left: 15px;
font-size: 15px;
font-weight: bold;
}
.peter99032j-xyz-panel-aside-main .panel-aside-main_____header >.header_____title >img{
display:block;
margin-right:5px;
width:25px;
height:25px;
}
.peter99032j-xyz-panel-aside-main .panel-aside-main_____header >.header_____close,
.peter99032j-xyz-panel-aside-main .panel-aside-main_____header >.header_____setting{
display: flex;
justify-content: center;
align-items: center;
cursor:pointer;
width:35px;
}
.peter99032j-xyz-panel-aside-main .panel-aside-main_____content{
flex: 1;
overflow: auto;
}
.peter99032j-xyz-panel-aside-main .panel-aside-main_____item{
padding: 5px;
margin:5px 0px;
}
.peter99032j-xyz-panel-aside-main .panel-aside-main_____item .item_____title{
font-size: 13px;
font-weight: 500;
text-align: center;
color: #b6b6b6;
padding: 5px 0px;
}
.peter99032j-xyz-panel-aside-main .panel-aside-main_____item .item_____container{
display: flex;
flex-flow: wrap;
flex-direction: row;
justify-content: flex-start;
}
/**** 历史记录展示 ****/
.peter99032j-xyz-panel-aside-main .histories-box-review_item{
width:33.3333%;
margin: 5px 0px;
overflow: hidden;
}
.peter99032j-xyz-panel-aside-main .histories-box-review_item >a{
display: block !important;
position: relative !important;
margin: 0px auto !important;
background-color: #fff !important;
width: 110px !important;
border-radius: 5px !important;
border: 1px solid #ccc !important;
box-sizing: content-box !important;
}
.peter99032j-xyz-panel-aside-main .histories-box-review_item > a >.review___shadow{
position:absolute;
left:0px;
right:0px;
top:0px;
bottom:0px;
z-index:99;
text-align: center;
border:2px solid red;
border-radius: 5px;
display:none;
}
.peter99032j-xyz-panel-aside-main .histories-box-review_item > a >.review___shadow .delete_____btn{
position: absolute;
top: 0px;
right: 0px;
width: 15px;
height: 15px;
text-align: center;
line-height: 10px;
background-color:red;
color:#FFF;
font-size:13px;
border-radius:3px;
}
.peter99032j-xyz-panel-aside-main .histories-box-review_item > a >.review___img{
width:110px;
height: 110px;
border-radius: 5px 5px 0px 0px;
overflow: hidden;
}
.peter99032j-xyz-panel-aside-main .histories-box-review_item > a >.review___img >img{
width:100%;
display:block;
}
.peter99032j-xyz-panel-aside-main .histories-box-review_item > a >.review___text{
text-align: center!important;
font-size: 13px !important;
color: #000 !important;
text-decoration: underline !important;
padding: 5px!important;
white-space: nowrap!important;
overflow: hidden!important;
text-overflow: ellipsis!important;
}
/*** 横向小卡片 ***/
.peter99032j-xyz-panel-wrapper >.peter99032j-xyz-panel-aside-body{
display: flex;
border-radius:5px;
overflow: hidden;
background-color: #fafafa;
-moz-box-shadow:2px 2px 5px #b6bdc5;
-webkit-box-shadow:2px 2px 5px #b6bdc5;
box-shadow:2px 2px 5px #b6bdc5;
height:60px;
}
.peter99032j-xyz-panel-wrapper >.peter99032j-xyz-panel-aside-body >div{
display: flex;
justify-content: center;
align-items: center;
}
.peter99032j-xyz-panel-aside-body .goods_____expand{
cursor: pointer;
width: 20px !important;
}
.peter99032j-xyz-panel-aside-body .goods_____expand svg{
transition: transform 0.3s;
}
/**** goods展示 ****/
.peter99032j-xyz-panel-aside-body .goods_____review{
flex-direction: row;
width:auto;
transition: all 0.5s ease-in-out;
}
.peter99032j-xyz-panel-aside-body .goods-review_____item{
width:45px;
height:45px;
line-height:45px;
margin:0px 5px;
position:relative;
border-radius: 4px;
overflow: hidden;
cursor:pointer;
}
.peter99032j-xyz-panel-aside-body .goods-review_____item >a{
display:block;
width: 100%;
height: 100%;
}
.peter99032j-xyz-panel-aside-body .goods-review_____item > a>.review___shadow{
position:absolute;
left:0px;
right:0px;
top:0px;
bottom:0px;
z-index:99;
text-align: center;
background-color:rgb(61 155 164 / 20%);
display:none;
}
.peter99032j-xyz-panel-aside-body .goods-review_____item > a>.review___shadow img{
width:15px;
display:inline;
}
.peter99032j-xyz-panel-aside-body .goods-review_____item img{
width:100%;
display:block;
}
/** 展开历史记录BOX **/
.peter99032j-xyz-panel-aside-body .history-box_____expand{
flex-direction: column;
text-align: center;
margin:0px 10px;
cursor: pointer;
}
.peter99032j-xyz-panel-aside-body .history-box_____expand img{
width:26px;
height:26px;
display:block;
}
.peter99032j-xyz-panel-aside-body .history-box_____expand label{
font-size:12px;
font-weight: bold;
}
.peter99032j-xyz-panel-aside-body .wrapper_____drag-handle{
width: 20px !important;
cursor: grab;
box-shadow: rgba(0, 0, 0, 0.2) 0px 3px 3px -2px, rgba(0, 0, 0, 0.14) 0px 3px 4px 0px, rgba(0, 0, 0, 0.12) 0px 1px 8px 0px;
}
`;
const histories = this.get(platform, 5);
const historyBase64 = "";
let goodsHtml = ``, jumpUrl = "";
histories.forEach((h)=>{
jumpUrl = commonFunctionObject.encryptStr(this.redirectUrl+encodeURIComponent(h.url));
goodsHtml += `
<div class="goods-review_____item">
<a title="`+h.title+`" jump-tag="true" jump-url="`+jumpUrl+`" target="_blank">
<div class="review___shadow">
<img src="" />
</div>
<img src="`+h.pic+`" />
</a>
</div>
`;
});
let html = `
<div class="peter99032j-xyz-panel-wrapper">
<div class="peter99032j-xyz-panel-aside-main">
<div class="panel-aside-main_____inner">
<div class="panel-aside-main_____header">
<div class="header_____title">
<img src="`+historyBase64+`"/>
浏览记录
</div>
<div class="header_____setting">
<svg class="icon-svg" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="1770" width="30" height="30"><path d="M811.04 468.728a39.72 39.72 0 0 0-27.672-30.36l-10.2-2.28a100.872 100.872 0 0 1-68.856-120.24l3.12-9.552a41.592 41.592 0 0 0-11.424-40.368 281.64 281.64 0 0 0-36.816-24.336c-12.36-7.2-25.224-13.536-38.496-18.912a41.592 41.592 0 0 0-41.592 9.984l-7.08 7.488a100.248 100.248 0 0 1-69.264 27.456 100.464 100.464 0 0 1-68.64-27.672l-6.864-7.272a41.592 41.592 0 0 0-41.592-9.984 294.96 294.96 0 0 0-37.848 18.912c-12.696 7.152-24.792 15.288-36.192 24.336a41.592 41.592 0 0 0-10.824 40.368l2.904 9.552a101.088 101.088 0 0 1-10.8 74.064 96.72 96.72 0 0 1-57.408 45.552l-9.792 2.28a35.352 35.352 0 0 0-26.616 28.488c-1.872 14.352-2.64 28.8-2.28 43.272-0.408 14.736 0.36 29.472 2.28 44.088a39.936 39.936 0 0 0 25.8 31.2l9.552 2.304a99 99 0 0 1 57.624 46.992c12.984 22.392 16.848 48.912 10.8 74.064l-2.064 9.36a41.592 41.592 0 0 0 11.856 40.344c11.136 9.072 22.968 17.28 35.352 24.552 12.312 7.488 25.176 14.016 38.496 19.536 14.64 4.608 30.624 0.768 41.592-9.984l6.648-7.272a101.088 101.088 0 0 1 139.152 0l6.672 7.272a41.592 41.592 0 0 0 41.592 9.984 295.152 295.152 0 0 0 37.224-19.536 271.848 271.848 0 0 0 36.624-24.336c10.944-10.32 15.48-25.752 11.856-40.368l-2.928-9.768a100.872 100.872 0 0 1 69.48-120l9.576-2.304a39.72 39.72 0 0 0 27.648-30.36c1.68-14.376 2.232-28.824 1.68-43.272a291.192 291.192 0 0 0-2.304-43.272z m-307.44 190.944a147.672 147.672 0 1 1 0-295.344 147.672 147.672 0 0 1 0 295.344z" fill="#8a8a8a" p-id="1771"></path></svg>
</div>
<div class="header_____close">
<svg class="icon-svg" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="1609" width="30" height="30"><path d="M673.5644448 281.66826667L512 447.82933333 351.16373333 281.71377813a44.6464 44.6464 0 0 0-63.6700448-0.50062293 46.1027552 46.1027552 0 0 0-0.50062186 64.6712896L447.82933333 512l-160.83626666 165.84248853c-17.52177813 18.06791147-17.29422187 46.8764448 0.50062186 64.6712896a44.69191147 44.69191147 0 0 0 63.71555627-0.45511146L512 576.17066667l161.5644448 165.93351146a44.78293333 44.78293333 0 0 0 63.7155552 0.4096 45.96622187 45.96622187 0 0 0 0.45511147-64.62577813L576.17066667 512l161.5644448-166.16106667a46.01173333 46.01173333 0 0 0-0.45511147-64.62577813 44.73742187 44.73742187 0 0 0-63.7155552 0.45511147z" fill="#5D6E7F" p-id="1610"></path></svg>
</div>
</div>
<div class="panel-aside-main_____content"></div>
</div>
</div>
<div class="peter99032j-xyz-panel-aside-body">
<div class="wrapper_____drag-handle">
<svg focusable="false" class="icon-svg" viewBox="0 0 24 24" data-testid="DragIndicatorIcon"><path d="M11 18c0 1.1-.9 2-2 2s-2-.9-2-2 .9-2 2-2 2 .9 2 2m-2-8c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2m0-6c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2m6 4c1.1 0 2-.9 2-2s-.9-2-2-2-2 .9-2 2 .9 2 2 2m0 2c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2m0 6c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2" fill="#bfbfbf"></path></svg>
</div>
<div class="history-box_____expand">
<img src="`+historyBase64+`"/>
<label>记录</label>
</div>
<div class="goods_____review">
`+goodsHtml+`
</div>
<div class="goods_____expand">
<svg t="1725284828401" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="1456" width="20" height="20"><path d="M706.15040002 97.8944a46.08 46.08 0 0 1-10.8544 29.9008L380.31360002 502.784a13.312 13.312 0 0 0 0 18.432l3.6864 3.072L695.29600002 896.2048a46.4896 46.4896 0 0 1-71.0656 59.8016l-311.0912-370.68799999a105.8816 105.8816 0 0 1 0-146.63680002l311.0912-370.68799999a46.2848 46.2848 0 0 1 81.92 29.9008z" fill="#bfbfbf" p-id="1457"></path></svg>
</div>
</div>
</div>
`;
GM_addStyle(css);
document.querySelector("body").insertAdjacentHTML('afterend', html);
this.addEventListener(platform);
};
this.addEventListener=function(platform){
const self = this;
const items = document.querySelectorAll(".goods_____review >.goods-review_____item >a");
items.forEach((ele)=>{
ele.addEventListener('mouseover', function() {
this.querySelector(".review___shadow").style.display="block";
});
ele.addEventListener('mouseout', function() {
this.querySelector(".review___shadow").style.display="none";
});
});
//展开底部tool商品
const goodsExpandEle = document.querySelector(".peter99032j-xyz-panel-wrapper .goods_____expand");
if(goodsExpandEle){
goodsExpandEle.addEventListener("click",function(e){
const goodsReviewEle = this.previousElementSibling;
const svgEle = this.querySelector("svg");
svgEle.style.transition = 'transform 0.3s';
if(goodsReviewEle.style.width=="0px"){
goodsReviewEle.style.width = "auto";
svgEle.style.transform = 'rotate(0deg)';
}else{
goodsReviewEle.style.width = "0px";
svgEle.style.transform = 'rotate(180deg)';
}
e.stopPropagation();
});
}
//历史记录大的box,关闭
const historyBoxExpandEles = [
document.querySelector(".peter99032j-xyz-panel-wrapper .history-box_____expand"),
document.querySelector(".peter99032j-xyz-panel-wrapper .header_____close")
];
const asideMainEle = document.querySelector(".peter99032j-xyz-panel-wrapper >.peter99032j-xyz-panel-aside-main");
if(asideMainEle){
historyBoxExpandEles.forEach((ele)=>{
if(ele){
ele.addEventListener("click", function(e){
if(!asideMainEle.style.display || asideMainEle.style.display==="none"){
self.showOrHideHistoryBox(platform);
asideMainEle.style.display="block";
}else{
asideMainEle.style.display="none";
}
e.stopPropagation();
});
}
});
}
//点击历史记录弹框以外的区域,影藏历史记录大的box
document.body.addEventListener("click",function(e){
if(asideMainEle.style.display && asideMainEle.style.display!=="none"){
asideMainEle.style.display="none";
}
});
//弹出设置弹窗
const headerSettingElement = document.querySelector(".peter99032j-xyz-panel-wrapper .header_____setting");
if(headerSettingElement){
headerSettingElement.addEventListener("click",()=>{
self.showSettingDialog();
});
}
//绑定点击事件
document.querySelectorAll(".peter99032j-xyz-panel-aside-body a[jump-tag='true']").forEach((ele)=>{
ele.addEventListener("click",function(e){
e.stopPropagation();
e.preventDefault();
const href = this.getAttribute("jump-url");
commonFunctionObject.GMopenInTab(commonFunctionObject.decryptStr(href));
});
});
// 添加右键移动
const draggable = document.querySelector(".peter99032j-xyz-panel-wrapper .wrapper_____drag-handle");
const wrapper = document.querySelector(".peter99032j-xyz-panel-wrapper");
let offsetX, offsetY;
const padding = 10;
const {width, height} = wrapper.getBoundingClientRect();
const offsetWrapper = Object.assign({}, this.defaultValue.offsetWrapper);
//移动操作
const move = (e)=>{
const {innerWidth, innerHeight } = window;
let x = e.clientX - offsetX;
let y = innerHeight - (e.clientY - offsetY) - height;
if(x < padding){
x = padding;
}else if(x > innerWidth/2){
x = innerWidth/2;
}
if(y < padding){
y = padding;
}else if(y > innerHeight - height - padding){
y = innerHeight - height - padding;
}
wrapper.style.left = x + 'px';
wrapper.style.bottom = y + 'px';
offsetWrapper.bottom = y;
offsetWrapper.left = y;
GM_setValue(this.storageKeys.offset, offsetWrapper)
}
if(draggable && wrapper){
draggable.addEventListener('mousedown', function(e){
offsetX = e.clientX - wrapper.offsetLeft;
offsetY = e.clientY - wrapper.offsetTop-10;
draggable.style.cursor="grabbing";
wrapper.style.userSelect="none";
document.addEventListener('mousemove',move);
});
document.addEventListener('mouseup', function(){
draggable.style.cursor="grab";
wrapper.style.userSelect="default";
document.removeEventListener("mousemove", move);
});
}
};
this.platform=function(){
const host = window.location.host;
const isForbidden = [
/^s\.click\.taobao\.com/,/^u\.jd\.com/,/^myseller\.taobao\.com/,
/^pro\.taobao\.com/,/^open\.taobao\.com/,/^jubao\.taobao\.com/,/^ishop\.taobao\.com/,
/^myseller\.taobao\.com/,/^trade\.taobao\.com/,/^sell\.taobao\.com/,/^fuwu\.taobao\.com/,
/^daxue\.taobao\.com/,/^healthcenter\.taobao\.com/,/^qn\.taobao\.com/,/^consumerservice\.taobao\.com/,/^helpcenter\.taobao\.com/,
/^market\.m\.taobao\.com/,/^jubao\.taobao\.com/,/^ipp\.taobao\.com/,
/^jr\.jd\.com/,/^diy\.jd\.com/,/^join\.jd\.com/,/^smart\.jd\.com/,/^baitiao\.jd\.com/,/^m\.jr\.jd\.com/,
/^trade\.jr\.jd\.com/,/^chongzhi\.jd\.com/,/^jiaofei\.jd\.com/,/^caipiao\.jd\.com/,/^jipiao\.jd\.com/,/^movie\.jd\.com/,
/^daojia\.jd\.com/,/^huishou\.jd\.com/,/^lai\.jd\.com/,/^mobile\.jd\.com/,/^b\.jd\.com/,/^fw\.jd\.com/,
/^lj\.jd\.com/,/^bxdl\.jd\.com/,/^about\.jd\.com/,
/^passport\.vip\.com/,/^jr\.vip\.com/,/^acs\.vip\.com/,/^help\.vip\.com/,/^h5rsc\.vip\.com/,/^rule\.vip\.com/
].map((reg)=>reg.test(host)).some((rs)=>rs==true);
if(isForbidden){
return;
}
const isVip = [/vip\.com/, /vipglobal\.hk/]
.map((reg)=>reg.test(host))
.some((rs)=>rs==true);
const isTaobao = [/taobao\.com/, /tmall\.com/, /tmall\.hk/, /liangxinyao\.com/]
.map((reg)=>reg.test(host))
.some((rs)=>rs==true);
const isJd = [/.jd\.com/, /jd\.hk/, /yiyaojd\.com/, /item\.jkcsjd\.com/]
.map((reg)=>reg.test(host))
.some((rs)=>rs==true);
if(isTaobao) return "taobao";
if(isJd) return "jd";
if(isVip) return "vpinhui";
return null;
};
this.start=function(){
let platform = this.platform();
if(platform){
if(platform=="tmall") platform="taobao";
this.createHistoryBox(platform);
this.registerMenuCommand();
}
};
}
function QueryCoupon(historyObject){
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"];
this.createQrcodeIsResult = true;
this.historyObject = historyObject;
this.isRun=function(){
for(var 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,"");
str = str.replace(/\r/g,"");
return encodeURIComponent(str)
};
this.getGoodsData=async function(platform){
var goodsId = "";
var goodsName = "";
const href = window.location.href;
if(platform=="taobao"){
goodsId = commonFunctionObject.getParamterQueryUrl(window.location.search, "id");
try{
const titleObj = document.querySelector("[class^='ItemTitle--']");
if(!!titleObj){
goodsName = titleObj.textContent;
}
}catch(e){}
}else if(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("[class='sku-name']");
if(!!titleObj){
goodsName = titleObj.textContent;
}
}catch(e){}
}else if(platform=="vpinhui"){
goodsId = commonFunctionObject.getEndHtmlIdByUrl(href).replace("detail-","");
const titleObj = document.querySelector("[class='pib-title-detail']");
if(!!titleObj){
goodsName = titleObj.textContent;
}
}
const data = {"goodsId":goodsId, "goodsName":this.filterName(goodsName)};
return data;
};
this.randomSpmValue=function(){
$("meta[name='data-spm']").each(function(){
var max = 5000;
var min = 1000;
var randomValue = Math.floor(Math.random() * (max - min + 1) ) + min;
var randomLetter = String.fromCharCode(Math.floor( Math.random() * 26) + "a".charCodeAt(0));
$(this).attr("content", randomValue+randomLetter);
});
$("meta[name='spm-id']").each(function(){
var max = 5000;
var min = 1000;
var randomValue = Math.floor(Math.random() * (max - min + 1) ) + min;
var randomLetter = String.fromCharCode(Math.floor( Math.random() * 26) + "a".charCodeAt(0));
$(this).attr("content", randomValue+randomLetter);
});
$("body").find("*").each(function(){
$(this).removeAttr("data-spm-anchor-id");
$(this).removeAttr("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,[]);
let saveContent = platform+"_"+goodsId;
if(!histories.includes(saveContent)){
histories.unshift(saveContent);
commonFunctionObject.GMsetValue(recordBrowsingHistoryKey,histories.slice(0,60));
}
};
this.browsingHistoryGoods=async function(platform, goodsId){
let recordPlatform = platform;
if(recordPlatform=="tmall"){ //淘宝,天猫合并为在一起
recordPlatform = "taobao";
}
const visitUrl = window.location.href;
let elementName = null;
if(/^https:\/\/detail\.tmall\.com\/item\.htm/.test(visitUrl)
|| /^https:\/\/item\.taobao\.com\/item\.htm/.test(visitUrl)
){
elementName={
"price":"span[class^='priceText--']",
"slider":"ul[class^='thumbnails--'] >li >img",
"title":"div[class^='ItemTitle--']>h1"
}
}else if(/^https:\/\/chaoshi\.detail\.tmall\.com\/item\.htm/.test(visitUrl)){
elementName={
"price":"span[class^='Price--priceText--']",
"slider":"ul[class^='PicGallery--thumbnails--'] img",
"title":"div[class^='ItemHeader--root--'] >h1"
}
}else if(/^https:\/\/detail\.tmall\.hk\/hk\/item\.htm/.test(visitUrl)){
elementName={
"price":"span[class^='Price--priceText--']",
"slider":"li[class^='PicGallery--thumbnail--'] img",
"title":"div[class^='ItemHeader--root--']>h1"
}
}else if(/^https:\/\/item\.jd\.com/.test(visitUrl)
|| /^https:\/\/npcitem\.jd\.hk/.test(visitUrl)
|| /^https:\/\/item\.yiyaojd\.com/.test(visitUrl)
|| /^https:\/\/item\.jkcsjd\.com/.test(visitUrl)
){
elementName={
"price":"span.p-price >.price",
"slider":"div[id^='main-img-'] img",
"title":"div[class='sku-name']"
}
}else if(/^https:\/\/detail\.vip\.com\/detail-/.test(visitUrl)){
elementName={
"price":"span.sp-price",
"slider":"#J-img-content img",
"title":"p.pib-title-detail"
}
}
if(elementName){
const promiseArray = [
commonFunctionObject.getElementObject(elementName.price, document.body, false, 100, 10*1000),
commonFunctionObject.getElementObject(elementName.slider, document.body, true, 100, 10*1000),
commonFunctionObject.getElementObject(elementName.title, document.body, true, 100, 10*1000),
];
Promise.all(promiseArray).then((elements)=>{
if(elements.length!=3){
return;
}
const priceElement = elements[0], sliderElement = elements[1], titleElement = elements[2];
if(sliderElement){
const imgSrc = sliderElement.getAttribute("src");
let price = priceElement ? priceElement.innerText : "--";
const title = titleElement ? titleElement.innerText : "--";
price = price.replace(/\t|\r|\s|¥|¥/g,"");
const goods = {"id":goodsId, "url":window.location.href, "pic":imgSrc, "date":(new Date()).getTime(), "price":price, "title":title}
this.historyObject.push(recordPlatform, goods);
}
});
}
};
this.createHtml=async function(platform, goodsId, goodsName){
if(!platform || !goodsId){
return "kong";
}
this.browsingHistoryMark(platform, goodsId); //把浏览记录给存在本地
this.browsingHistoryGoods(platform, goodsId); //把商品记录下来,包括title、价格和主图
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,reject) =>{ resolve(document.body) })
);
}else if(eleName=="html"){
promiseArray.push(
new Promise((resolve,reject) =>{ resolve(document.html) })
);
}else{
promiseArray.push(commonFunctionObject.getElementObject(eleName, document.body, true, 10, 1500));
}
}
const element = await Promise.race(promiseArray);
return element ? element : null;
}
const element = await getElement(handler);
return new Promise((resolve,reject) =>{
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 cssText = result.css, htmlText = result.html, handler = result.handler, templateId = result.templateId;
if(!cssText || !htmlText || !handler){
return;
}
GM_addStyle(cssText);
// 添加HTML, 需要动态检测元素
const handlerElement = await this.getHandlerElement(handler);
if(handlerElement){
const $handlerElement = $(handlerElement);
if(platform=="taobao"){
$handlerElement.parent().after(htmlText);
}else if(platform=="tmall"){
$handlerElement.parent().after(htmlText);
}else if(platform=="jd"){
$handlerElement.after(htmlText);
}else if(platform=="vpinhui"){
$handlerElement.after(htmlText);
}
}
const $template = $("#"+templateId);
if($template.length == 0){
return;
}
const couponId = $template.data("id");
const goodsPrivateUrl = "https://j.jiayoushichang.com/api/private/change/coupon?script=7&platform="+platform+"&id=";
if(!/\d/.test(couponId)){
return;
}
setInterval(()=>{
$template.find("*").each(function(){
$(this).removeAttr("data-spm-anchor-id");
});
},400);
const couponElementA = $template.find("a[name='cpShUrl']");
couponElementA.unbind("click").bind("click", ()=>{
event.stopPropagation();
event.preventDefault();
commonFunctionObject.request("GET", goodsPrivateUrl+couponId, null).then((privateResultData)=>{
if(privateResultData.result==="success" && !!privateResultData.data){
let url = JSON.parse(privateResultData.data).url;
if(!!url) GM_openInTab(url, {active:true});
}
});
});
//canvas画二维码
var $canvasElement = $("#ca"+templateId);
if($canvasElement.length == 0){
return;
}
const qrcodeResultData = await commonFunctionObject.request("GET", goodsPrivateUrl+couponId, null);
if(!!qrcodeResultData && qrcodeResultData.result==="success" && !!qrcodeResultData.data){
let img = JSON.parse(qrcodeResultData.data).img;
if(!!img){
var canvasElement = document.getElementById("ca"+templateId);
var cxt = canvasElement.getContext("2d");
var imgData = new Image();
imgData.src = img;
imgData.onload=function(){
cxt.drawImage(imgData, 0, 0, imgData.width, imgData.height);
}
}
}
}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){
$(mount).append(html);
var canvasElement = document.getElementById("mscan"+iden);
var width = canvasElement.getAttribute("width");
var height = canvasElement.getAttribute("height");
var cxt = canvasElement.getContext("2d");
var 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;
//如果sku太多就折叠,不然移动端体验太差了
if(platform=="tmall" || platform=="taobao"){
commonFunctionObject.getElementObject("[class='skuItemWrapper']", document.body, false, 10, 1500).then((skuItemWrapper)=>{
if(skuItemWrapper != null){
const { style } = skuItemWrapper;
style.maxHeight = "350px";
style.overflow = "auto";
}
}).catch(()=>{});
}
const goodsData = await this.getGoodsData(platform);
this.createHtml(platform, goodsData.goodsId, goodsData.goodsName);
}
};
}
function SearchPageObject(historyObject){
this.intervalIsRunComplete = true; //定时任务一个循环是否完成
this.histories = commonFunctionObject.GMgetValue(recordBrowsingHistoryKey, []);
this.pickupSearchElements=function(){ //收集列表的元素
const selectorElementList = new Array();
const url = window.location.href;
if(url.indexOf("://s.taobao.com/search")!=-1 || url.indexOf("://s.taobao.com/list")!=-1) { //淘宝搜索页面
selectorElementList.push({"element":".items >.item", "page":"taobao"});
selectorElementList.push({"element":".Content--content--sgSCZ12 .Card--doubleCardWrapper--L2XFE73", "page":"taobao_new"});
selectorElementList.push({"element":".Content--content--sgSCZ12 .Card--listCardWrapper--ax09OfT", "page":"taobao_new"});
selectorElementList.push({"element":".Content--content--sgSCZ12 .Card--doubleCardWrapperMall--uPmo5Bz", "page":"taobao_new"});
selectorElementList.push({"element":".Content--content--sgSCZ12 .Card--listCardWrapperMall--E3jI8L4", "page":"taobao_new"});
}else if(url.indexOf("taobao.com/category")!=-1){ //淘宝店铺分类
selectorElementList.push({"element":"dl.item", "page":"taobao_category"});
}else if(url.indexOf("taobao.com/search.htm")!=-1){ //淘宝店铺搜索
selectorElementList.push({"element":"dl.item", "page":"taobao_shop_search"});
}
else if (url.indexOf("://list.tmall.com/search_product.htm")!=-1 || url.indexOf("://list.tmall.com//search_product.htm")!=-1
|| url.indexOf("://list.tmall.com/coudan/search_product.htm")!=-1
|| url.indexOf("://pages.tmall.com/wow/an/cs/search")!=-1) { //天猫超市
selectorElementList.push({"element":".product", "page":"tmall_chaoshi_search"});
selectorElementList.push({"element":".chaoshi-recommend-list .chaoshi-recommend-item", "page":"tmall_chaoshi_search_new"}); //新天猫超市
selectorElementList.push({"element":".feeds-list .feeds-item", "page":"tmall_chaoshi_search_20240115"}); //天猫超市新页面https://pages.tmall.com/wow/an/cs/search%2F18a4077f847?spm=a3204.7084713.1996500281.13.z3hXwd&s=0&user_id=725677994&area_code=330100&cat=50514029&active=1&style=g&acm=lb-zebra-27092-331852.1003.4.457104&search_condition=1&sort=s&scm=1003.4.lb-zebra-27092-331852.OTHER_14434954372593_457104&n=40#/?q=%E7%89%99%E8%86%8F&sort=s&page_no=1&spos=&brand=&prop=&cat=50514008
}else if (url.indexOf("//list.tmall.hk/search_product")!=-1) { //天猫国际
selectorElementList.push({"element":"#J_ItemList .product", "page":"tmall_hk"});
}else if(url.indexOf("tmall.com/category-")!=-1){ //天猫分类
selectorElementList.push({"element":"#J_ShopSearchResult dl.item", "page":"tmall_category"});
}else if(url.indexOf("tmall.com/category-")!=-1){ //天猫旗舰店分类
selectorElementList.push({"element":"#J_ShopSearchResult dl.item", "page":"tmall_category"});
}else if(url.indexOf(".tmall.com/shop/view_shop.htm")!=-1){ //天猫旗舰全部展示
selectorElementList.push({"element":"dl.item", "page":"tmall_shop_01"});
}else if(url.indexOf(".tmall.com/search.htm")!=-1){
selectorElementList.push({"element":"dl.item", "page":"tmall_shop_search"});
}
else if(url.indexOf("//maiyao.liangxinyao.com/shop/view_shop.htm")!=-1
|| url.indexOf("//maiyao.liangxinyao.com/search.htm")!=-1
|| url.indexOf("//maiyao.liangxinyao.com/category")!=-1){ //阿里大药房
selectorElementList.push({"element":"#J_ShopSearchResult dl.item", "page":"ali_yao"});
}
else if (url.indexOf("//search.jd.com/Search")!=-1 || url.indexOf("//search.jd.com/search")!=-1) { //京东搜索
selectorElementList.push({"element":"#J_goodsList li.gl-item", "page":"jd_search"});
}else if(url.indexOf("//search.jd.hk/Search")!=-1){ //京东国际https://search.jd.hk/Search?keyword=ds
selectorElementList.push({"element":"#plist li.gl-item", "page":"jd_hk_search"}); //可能已弃用
selectorElementList.push({"element":"li[class^='productList_']", "page":"jd_hk_new_search"});//20240119添加
}else if(url.indexOf("//mall.jd.com/view_search")!=-1){ //京东大药房
selectorElementList.push({"element":"li.jSubObject", "page":"jd_yao_search"});
}else if(url.indexOf("www.jd.com")!=-1 && window.location.pathname=="/"){
selectorElementList.push({"element":"#feedContent0 li.more2_item_good", "page":"jd_homepage"});
}
else if(url.indexOf("category.vip.com/suggest.php")!=-1){
selectorElementList.push({"element":"#J_searchCatList .c-goods-item", "page":"vpinhui_search_page"});
}else if(url.indexOf("://list.vip.com")!=-1){
selectorElementList.push({"element":"#J_wrap_pro_add .c-goods-item", "page":"vpinhui_list"});
}
return selectorElementList;
};
this.createAllElementHtml=function(elementData){ //为所有的商品创建提示
const self = this;
$(elementData.element).each(function(){ //遍历所有的商品框
self.createOneElementHtml($(this), elementData);
});
self.intervalIsRunComplete = true;
};
this.markBrowsingHistory=function($element, mark){
if(this.histories.includes(mark)){
$element.append(browsedHtml);
}
};
/**
* 为商品box添加有券提醒
* @param {Object} $element 每一个商品box
* @param {Object} elementData id and page
*/
this.createOneElementHtml=async function($element, elementData){ //查询到每个商品list
if($element.attr("honghaoerbox")){ //当存在时,说明已经处理过了
return;
}
const self = this;
$element.attr("honghaoerbox","true");
$element.css("position","relative");
var page = elementData.page;
var goodsDetailUrl = null;
if(page==="taobao"){
goodsDetailUrl = $element.find("a[id^='J_Itemlist_TLink_']").attr("href");
}else if(page==="taobao_new"){
let href = $element.attr("href");
goodsDetailUrl = href.indexOf("http") == -1 ? (location.protocol + href) : href;
}else if(page==="taobao_category"){
goodsDetailUrl = $element.find(".J_TGoldData").attr("href");
}else if(page==="taobao_shop_search"){
goodsDetailUrl = $element.find(".J_TGoldData").attr("href");
}else if(page==="ali_yao"){
goodsDetailUrl = $element.find(".J_TGoldData").attr("href");
}else if(page==="tmall_chaoshi_search"){
let href = $element.find("div.product-img").find("a").attr("href");
goodsDetailUrl = href.indexOf("http") ==-1 ? (location.protocol + href) : href;
}else if(page==="tmall_chaoshi_search_new"){
let href = !!$element.attr("href")?$element.attr("href"):$element.find("a").attr("href");
goodsDetailUrl = href.indexOf("http") ==-1 ? (location.protocol + href) : href;
}else if(page==="tmall_hk"){
goodsDetailUrl = $element.find("a.productImg").attr("href");
}else if(page==="tmall_category"){
goodsDetailUrl = $element.find(".J_TGoldData").attr("href");
}else if(page==="tmall_shop_01"){
goodsDetailUrl = $element.find("dt.photo").find("a").attr("href");
}else if(page==="tmall_shop_search"){
goodsDetailUrl = $element.find(".J_TGoldData").attr("href");
}else if(page=="tmall_chaoshi_search_20240115"){
goodsDetailUrl = $element.find("a").attr("href");
}
else if(page==="jd_search"){
goodsDetailUrl = $element.find("div.p-img").find("a").attr("href");
}else if(page==="jd_hk_search"){
goodsDetailUrl = $element.find("div.p-img").find("a").attr("href");
}else if(page==="jd_hk_new_search"){
goodsDetailUrl = $element.find("a").attr("href");
}else if(page==="jd_yao_search"){
goodsDetailUrl = $element.find("div.jPic").find("a").attr("href");
}else if(page=="jd_homepage"){
goodsDetailUrl = $element.find("a[class='more2_lk']").attr("href");
}
else if(page=="vpinhui_search_page"){
goodsDetailUrl = $element.find("a").attr("href");
}else if(page=="vpinhui_list"){
goodsDetailUrl = $element.find("a").attr("href");
}
if(!goodsDetailUrl){
return;
}
var analysisData = null;
if(page.indexOf("jd_")!=-1){
var jdId = commonFunctionObject.getEndHtmlIdByUrl(goodsDetailUrl);
if(!!jdId) analysisData = {"id":jdId, "platform":"jd"};
}else if(page.indexOf("vpinhui_")!=-1){
var vipId = commonFunctionObject.getEndHtmlIdByUrl(goodsDetailUrl).replace("detail-","");;
if(!!vipId){
analysisData = {"id":vipId.split("-")[1], "platform":"vpinhui"};
}
}else{
var platform = commonFunctionObject.getEcommercePlatform(goodsDetailUrl);
var id = commonFunctionObject.getParamterQueryUrl(goodsDetailUrl, "id");
if(platform && id){
analysisData = {"id":id, "platform":platform};
}
}
if(!analysisData){
return;
}
this.markBrowsingHistory($element, analysisData.platform + "_" + analysisData.id);
try{
const searchUrl = "https://j.jiayoushichang.com/api/ebusiness/coupon/exist/"+analysisData.platform+"?id="+analysisData.id;
const data = await commonFunctionObject.request("GET", searchUrl, null);
if(data.result=="success" && !!data.data){
const { tip, encryptLink } = JSON.parse(data.data);
if(tip){
$element.append(tip);
}
if(encryptLink){
let decryptUrl = null;
try{
const decryptLink = atob(encryptLink);
decryptUrl = decryptLink.split('').reverse().join('');
}catch(e){}
if(decryptUrl){
self.relativeJu(page, $element, decryptUrl);
}
}
}
}catch(e){
console.log("查券出现异常",e);
}
};
this.relativeJu=function(page, $element, decryptUrl){
const self = this;
try{
if(page.indexOf("jd_")!=-1){
$element.find("a").each(function(){
if($(this).attr("href").indexOf("item.jd.com")!=-1){
$(this).removeAttr("onclick");
$(this).unbind("click").bind("click", function(e){
e.preventDefault();
e.stopPropagation();
commonFunctionObject.GMopenInTab(decryptUrl);
});
}
});
}
else if(page.indexOf("taobao_")!=-1 || page.indexOf("tmall_")!=-1){
$element.unbind("click").bind("click",function(e){
const target = $(e.target);
const tagName = target.prop("tagName").toUpperCase();
let isPreventDefault = false;
if(tagName==="A"){ //只有点击A标签才去判断
const href = target.attr("href");
const isDetail = [/detail\.tmall\.com\/item\.htm/, /item\.taobao\.com\/item\.htm/]
.map((reg)=> reg.test(href))
.some((result) => result);
if(isDetail){
isPreventDefault = true;
}
}else{
isPreventDefault = true;
}
if(isPreventDefault){
e.preventDefault();
e.stopPropagation();
commonFunctionObject.GMopenInTab(decryptUrl);
}
});
}
else if(page.indexOf("vpinhui_")!=-1){
$element.find("a").each(function(){
if($(this).attr("href").indexOf("detail.vip.com/detail-")!=-1){
$(this).unbind("click").bind("click", function(e){
e.preventDefault();
e.stopPropagation();
commonFunctionObject.GMopenInTab(decryptUrl);
});
}
});
}
}catch(e){
console.log(e);
}
};
this.searchPage=function(selectorElementList){
if(!this.intervalIsRunComplete){
return;
}
selectorElementList.forEach((elementData)=>{
if(!!elementData){
this.createAllElementHtml(elementData);
}
});
}
this.start=function(){
const selectorElementList = this.pickupSearchElements();
selectorElementList.forEach((elementData)=>{
if(!!elementData){
$("body").on("click",elementData.element,function(){
$(this).append(browsedHtml);
});
}
});
setInterval(()=>{
this.searchPage(selectorElementList);
}, 1000);
};
}
try{
const historyObject = new HistoryObject();
(new SearchPageObject(historyObject)).start();
(new QueryCoupon(historyObject)).start();
historyObject.start();
}catch(e){
console.log("优惠券查询:error:"+e);
}
/**
* 代码借鉴子: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 = /<a\s+(?:[^>]*?\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=`<svg t="1724300009050" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="5307" width="35" height="35"><path d="M298.666667 554.666667v85.333333H256v128h512v-128h-42.666667v-85.333333h128v213.333333a85.333333 85.333333 0 0 1-78.933333 85.077333L768 853.333333H256a85.333333 85.333333 0 0 1-85.12-78.933333L170.666667 768v-213.333333h128z" fill="#ffffff" p-id="5308"></path><path d="M512 627.498667l219.477333-219.477334h-120.704L512 506.88 413.141333 408.021333H292.522667L512 627.498667z" fill="#ffffff" p-id="5309"></path><path d="M554.666667 528V167.978667h-85.333334v360.021333h85.333334z" fill="#ffffff" p-id="5310"></path></svg>`;
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;
}
let downloadOption = [{name:'',id:'toServer'}, {name:'打开视频(可下载)',id:'toLink'}];
let videoElements = document.querySelectorAll('video');
if(videoElements.length == 0) return;
//把自动播放的video标签选择出来
let playVideoElements=[];
videoElements.forEach(function(element){
let autoplay = element.getAttribute('autoplay');
if(autoplay !== null){
playVideoElements.push(element);
}
})
let videoContainer=location.href.indexOf('modal_id') != -1
? playVideoElements[0]
: playVideoElements[playVideoElements.length-1];
if(!videoContainer) return;
//获取视频播放地址
let url = videoContainer && videoContainer.children.length>0 && videoContainer.children[0].src
? videoContainer.children[0].src
: videoContainer.src;
//获取视频ID,配合自定义id使用
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')
}
let playContainer = videoContainer.parentNode.parentNode.querySelector('.xg-right-grid');
if(!playContainer) return;
//在对主页就行视频浏览时会出现多个按钮,删除不需要的,只保留当前对应的
let videoDownloadDom = playContainer.querySelector('#scriptVideoDownload'+videoId);
if(videoDownloadDom){
let dom = playContainer.querySelectorAll('.xgplayer-playclarity-setting');
dom.forEach(function(d){
let btn = d.querySelector('.btn');
if(d.id != 'scriptVideoDownload'+videoId && btn.innerText=='下载'){
d.parentNode.removeChild(d);
}
});
return;
}
if(videoContainer && playContainer){
let playClarityDom = playContainer.querySelector('.xgplayer-playclarity-setting');
if(!playClarityDom) return;
let palyClarityBtn = playClarityDom.querySelector('.btn');
if(!palyClarityBtn) return;
let downloadDom = playClarityDom.cloneNode(true);
downloadDom.setAttribute('id','scriptVideoDownload'+videoId);
if(location.href.indexOf('search') == -1){
downloadDom.style='margin-top:-68px;padding-top:100px;padding-left:20px;padding-right:20px;';
}else{
downloadDom.style='margin-top:0px;padding-top:100px;';
}
let downloadText = downloadDom.querySelector('.btn');
downloadText.innerText='下载';
downloadText.style = 'font-size:14px;font-weight:600;';
downloadText.setAttribute('id','zhmDouyinDownload'+videoId);
let detail = playContainer.querySelector('xg-icon:nth-of-type(1)').children[0];
let 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);');
let virtualDom = downloadDom.querySelector('.virtual');
downloadDom.onmouseover=function(){
if(location.href.indexOf('search') == -1){
virtualDom.style='display:block !important';
}else{
virtualDom.style='display:block !important;margin-bottom:37px;';
}
}
downloadDom.onmouseout=function(){
virtualDom.style='display:none !important';
}
let downloadHtml = '';
downloadOption.forEach(function(item){
if(item.id=="toServer"){
downloadHtml += `<div style="text-align:center;width:100px;" class="item ${item.id}" id="${item.id}${videoId}">AI视频分析<span style="color:red;">(热门)</span></div>`;
}else{
downloadHtml += `<div style="text-align:center;width:100px;" class="item ${item.id}" id="${item.id}${videoId}">${item.name}</div>`;
}
})
if(downloadDom.querySelector('.virtual')){
downloadDom.querySelector('.virtual').innerHTML = downloadHtml;
}
playClarityDom.after(downloadDom);
//直接打开
let toLinkDom = playContainer.querySelector('#toLink'+videoId);
if(toLinkDom){
toLinkDom.addEventListener('click',function(){
if(url.match(/^blob/)){
commonFunctionObject.webToast({"message":"加密视频无法直接打开。可复制分享链,重新打开页面使用“下载”", "background":"#141414"});
}else{
window.open(url);
}
})
}
let 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){
var html=`<div style="position:fixed;left:15px;bottom:300px;background-color:#ccc;width:200px;font-size:14px;padding:5px;">
<div style="color:red;font-weight:bold;">直接下载已经失效,需要在视频框点击:鼠标右键 ->视频另存为,然后保存视频</div>
<div style="margin-top:15px;"># 纯纯的资源分享,需要的自取:<a target="_blank" href="https://www.quzhuanpan.com/redirect/pan?t=`+(new Date()).getTime()+`&url=`+window.location.href+`">点我查看【建议保存】</a></div>
<div style="margin-top:15px;"># 效率工具,免费AI总结/摘要/改写/翻译,支持搜索学术文献一键阅读:<a target="_blank" href="https://www.quzhuanpan.com/redirect/d?t=`+(new Date()).getTime()+`&url=`+window.location.href+`">点我查看</a></div>
</div>`;
$("body").append(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){
let downloadDIV = document.createElement("div");
downloadDIV.style = "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){
let videoDom = document.querySelector('.player-video');
if(!videoDom){
console.log('没有找到DOM');
return;
}
let 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(){
let 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);
}
})();