在您安裝前,Greasy Fork希望您了解本腳本包含“可能不受歡迎的功能”,可能幫助腳本的作者獲利,而不能給你帶來任何收益。
此腳本會在您造訪的網站插入廣告。
加速无止境!百度网盘SVIP解析加速下载脚本,支持谷歌 IE 等浏览器,操作简单,一键下载文件!
// ==UserScript== // @name 百度网盘SVIP解析不限速下载-🔥天天加速🔥 // @namespace http://tampermonkey.net/ // @version 1.9 // @description 加速无止境!百度网盘SVIP解析加速下载脚本,支持谷歌 IE 等浏览器,操作简单,一键下载文件! // @antifeature ads // @author You // @icon  // @license MIT // @icon https://nd-static.bdstatic.com/m-static/v20-main/home/img/icon-home-new.b4083345.png // @match *://pan.baidu.com/* // @match *://yun.baidu.com/* // @match *://pan.baidu.com/disk/home* // @match *://yun.baidu.com/disk/home* // @match *://pan.baidu.com/disk/main* // @match *://yun.baidu.com/disk/main* // @match *://pan.baidu.com/s/* // @match *://yun.baidu.com/s/* // @match *://pan.baidu.com/share/* // @match *://yun.baidu.com/share/* // @connect baidu.com // @connect api.aifenxiang.net.cn // @connect 127.0.0.1 // @grant GM_cookie // @grant GM_addStyle // @grant GM_getResourceText // @grant GM_xmlhttpRequest // @require https://cdnjs.cloudflare.com/ajax/libs/layui/2.9.14/layui.min.js // @require https://unpkg.com/sweetalert/dist/sweetalert.min.js // @resource layuiCSS https://cdnjs.cloudflare.com/ajax/libs/layui/2.9.14/css/layui.css // ==/UserScript== (function () { 'use strict'; const layuicss = GM_getResourceText('layuiCSS'); GM_addStyle(layuicss); layui.use(['layer'], async function () { var layer = layui.layer, $ = layui.$; var form = layui.form; if (location.href.startsWith('https://pan.baidu.com/s/')) { $('.x-button-box').prepend( '<a class="g-button" id="downbtn_share" style="background-color: red;color: #fff;border:none;" href="javascript:;" ><span class="g-button-right"><em style="top:0;" class="icon icon-download" title=""></em><lable class="text" style="width: auto;">' + config.title_name + '</lable></span></a>' ); } else { if ($('.tcuLAu').is('*')) { $('.tcuLAu').prepend( '<span class="g-dropdown-button"><a id="downbtn_main" style=" margin-right: 10px;color: #fff;background-color: red;border:none;" id="downbtn_main" class="g-button" ><span class="g-button-right"><em style="top:0;" class="icon icon-download" ></em><lable class="text" style="width: auto;">' + config.title_name + '</lable></span></a></span>' ); } else { $('.wp-s-agile-tool-bar__header.is-header-tool').prepend( '<div class="wp-s-agile-tool-bar__h-group"><button style=" margin-right: 10px;color: #fff;background-color: red;border:none;" id="downbtn_main" class="u-button nd-file-list-toolbar-action-item" ><i style="top:0;" class="iconfont icon-download"></i> <lable>' + config.title_name + '</lable></button></div>' ); } } $('#downbtn_share').click(function () { swal({ title: '提示', text: '请先保存到自己的网盘后,从网盘里解析!', icon: 'warning', }); return false; }); $('#downbtn_main').click(function () { let select = selectList(); let selected = Object.keys(select); if (selected.length == 0) { swal({ text: '请先选择一个文件', icon: 'warning', }); return false; } else if (selected.length > 1) { swal({ text: '目前仅支持单个文件解析', icon: 'warning', }); return false; } else if (select[selected[0]].isdir == 1) { swal({ text: '目前不支持文件夹解析', icon: 'warning', }); return false; } const newDiv = document.createElement('div'); let createDiv = ` <div> <img src="https://bd.shzxkq.com/xcx.jpg" style="width:240px;height:240px;"> </div> <div> <input style="border:1px solid #ccc; width:60%;height:40px;text-indent:20px;" type="text" autocomplete="off" placeholder="请输入验证码" id="wpCode"/> </div> `; newDiv.innerHTML = createDiv; const openLayer = layer.open({ type: 1, // page 层类型 area: ['450px', '300px'], title: '提示', shade: 0.6, // 遮罩透明度 shadeClose: true, // 点击遮罩区域,关闭弹层 anim: 0, // 0-6 的动画形式,-1 不开启 content: ` <div class="layui-form" lay-filter="filter-test-layer" style="width:360px;margin: 16px auto 0;"> <div class="demo-login-container"> <div style="margin-top:50px;">插件解析限制两次</div> <div>下载器一定要配置端口: <a style="color:green;" target="_blank" href="https://docs.qq.com/doc/DWnlpY2pkclpuUEFX?no_promotion=1">点击查看配置说明</a></div> <div>不限次数pc网页稳定版: <a style="color:green;" target="_blank" href="https://aifenxiang.net.cn">点击前往</a></div> <button style="margin-left:0;margin-top:50px;" id="parse" class="layui-btn layui-btn-fluid" lay-submit lay-filter="demo-login">解析</button> </div> </div> `, success: function () { // 对弹层中的表单进行初始化渲染 form.render(); // 表单提交事件 form.on('submit(demo-login)', async function (data) { $('#parse').html('<p>正在解析中请稍后...</p>'); //let field = data.field; // 获取表单字段值 let canDown = await testDownLoad(); if (!canDown) { layer.close(openLayer); swal("请先安装高速下载器!", "下载地址:https://pan.quark.cn/s/b878b162bb5b", "warning"); $('#parse').html('<p>解析</p>'); return; } share_one_baidu(openLayer); }); }, }); }); }); function selectList() { var select = {}; var option = []; try { option = require('system-core:context/context.js').instanceForSystem.list.getSelected(); } catch (e) { option = document.querySelector('.wp-s-core-pan').__vue__.selectedList; } option.forEach((element) => { select[element.fs_id] = element; }); return select; } const config = { main_url: 'https://api.aifenxiang.net.cn', //main_url: 'http://127.0.0.1:8081', bd_password: '1234', title_name: '天天加速', }; function share_one_baidu(openLayer) { let select = Object.keys(selectList()); let bdstoken = ''; let data_json = {}; try { data_json = $('html') .html() .match(/(?<=locals\.mset\()(.*?)(?=\);)/)[0]; data_json = JSON.parse(data_json); config.username = data_json.username; bdstoken = data_json.bdstoken; } catch (e) { data_json = $('html') .html() .match(/(?<=window\.locals\s=\s)(.*?)(?=;)/)[0]; data_json = JSON.parse(data_json); config.username = data_json.userInfo.username; bdstoken = data_json.userInfo.bdstoken; } config.data_json = data_json; const param = { bdstoken: bdstoken, period: 1, pwd: config.bd_password, eflag_disable: true, channel_list: '%5B%5D', schannel: 4, fid_list: JSON.stringify(select), }; $.ajax({ type: 'GET', url: 'https://pan.baidu.com/share/set', async: true, data: { bdstoken: bdstoken, period: 1, pwd: config.bd_password, eflag_disable: true, channel_list: '%5B%5D', schannel: 4, fid_list: JSON.stringify(select), }, dataType: 'json', success: function (res) { if (res.show_msg.indexOf('禁止') > -1) { swal({ text: '该文件禁止分享', icon: 'error', }); return false; } else { let shorturl = ''; try { shorturl = res.link.split('/').pop(); } catch (error) { swal({ text: '初始化准备失败', icon: 'error', }); return false; } fetch(config.main_url + '/wp/down/num', { method: 'POST', headers: { 'Content-Type': 'application/json', }, body: JSON.stringify({ userKey: 'main', fsId: select[0], version: '1.0.1', }), }) .then((resp) => resp.json()) .then((res) => { let laysermsg = layer.msg('正在解析中', { icon: 6, time: 10000, // 7秒后自动关闭 }); if (res.code == 200) { if (res.data > 100) { get_down_list( shorturl, config.bd_password, openLayer, res.data, laysermsg ); } else if (res.data == 80) { layer.msg('解析中', { icon: 6, time: 3000, // 3秒后自动关闭 }); setTimeout(() => { $('#parse').html('<p>解析</p>'); layer.alert('解析通道比较拥堵,请重试!', { title: '提示', }); }, 3000); } else if (res.data == 60) { layer.msg('解析中', { icon: 6, time: 3000, // 3秒后自动关闭 }); setTimeout(() => { $('#parse').html('<p>解析</p>'); layer.close(openLayer); swal("解析次数已达上限", "请使用不限次数稳定版:https://www.aifenxiang.net.cn", "warning"); }, 3000); } else if (res.data == 50) { layer.alert( '验证码错误,一个验证码只能下载一个文件,请重新获取!', { title: '提示', } ); } else { layer.alert( '验证码错误,一个验证码只能下载一个文件,请重新获取!', { title: '提示', } ); } } else if (res.code == 500) { layer.close(openLayer); layer.close(laysermsg); swal({ text: res.msg, icon: 'warning', }); } }); } }, error: function (res) { swal({ text: '初始化准备请求访问失败', icon: 'error', }); }, }); } async function get_down_list(shorturl, password, openLayer, pwd, laysermsg) { let ajax_data = { shorturl: shorturl, pwd: password, dir: 1, root: 1, userKey: 'main', }; fetch(config.main_url + '/wp/parseCopyLink', { method: 'POST', headers: { 'Content-Type': 'application/json', }, body: JSON.stringify(ajax_data), }) .then((resp) => resp.json()) .then((res) => { if (res.code == 200) { const size = parseInt(res.data.data.list[0].size); if (size > 3221225472) { layer.close(openLayer); layer.close(laysermsg); $('#parse').html('<p>解析</p>'); swal("文件大于3G,插件暂不支持下载", "请前往PC网页版下载:https://www.aifenxiang.net.cn", "warning"); return false; } console.log(res); const requestData = { fsId: res.data.data.list[0].fs_id, shareid: res.data.data.shareid, uk: res.data.data.uk, sekey: res.data.data.seckey, randsk:res.data.data.seckey, fs_ids: [res.data.data.list[0].fs_id], path:res.data.data.list[0].server_filename, size:res.data.data.list[0].size, surl: shorturl, url: `https://pan.baidu.com/s/${shorturl}`, userKey: 'main', pwd: password, dir: '/', }; console.log(requestData); GM_xmlhttpRequest({ method: 'POST', url: config.main_url + '/wp/dlink', headers: { 'Content-Type': 'application/json', }, data: JSON.stringify(requestData), onload: function (response) { const responseData = JSON.parse(response.responseText); if (responseData.code !== 200) { layer.close(openLayer); layer.close(laysermsg); swal({ text: responseData.msg, icon: 'warning', }); } else { layer.close(laysermsg); layer.close(openLayer); $('#parse').html('<p>解析</p>'); if(responseData.data.vip){ config.url = responseData.data.data.dlink; config.ua = responseData.data.data.ua; }else{ config.url = responseData.data.data.urls[0].url; config.ua = responseData.data.data.ua; } sendToMotrix(res.data.data.list[0]); } }, onerror: function (response) { layer.close(openLayer); layer.close(laysermsg); const errorMessage = JSON.parse(response.responseText).message || '网络错误'; swal({ text: '解析遇到问题了,请刷新重试即可!!', icon: 'warning', }); }, }); } else { layer.close(openLayer); layer.close(laysermsg); $('#parse').html('<p>解析</p>'); swal({ text: '解析遇到问题了,请升级插件刷新重试即可!', icon: 'warning', }); } }); } function sendToMotrix(item) { fetch('http://127.0.0.1:9999/api/v1/tasks', { method: 'POST', headers: { 'Content-Type': 'application/json' }, body: JSON.stringify({ req: { url:config.url, extra:{ header:{ "User-Agent":config.ua, } } }, opt:{ extra:{ connections:256, } } }), }).then((resp) => resp.json()) .then((res) => { swal("解析成功", `${item.server_filename}开始下载,请打开下载器查看!`, "success"); }).catch(e=>{ }) } setInterval(()=>{ GM_xmlhttpRequest({ method: 'get', url: 'http://127.0.0.1:9999/api/v1/tasks?status=running', headers: { 'Content-Type': 'application/json', }, onload: function (response) { const responseData = JSON.parse(response.responseText); const result = responseData.data.filter(e=> e.status === "running" ).filter((e)=>e.progress.speed < 1048576).map(e=>e.id); const ids = result.map((e)=>{ return `id=${e}` }).join('&') if(ids && ids.length){ GM_xmlhttpRequest({ method: 'put', url: `http://127.0.0.1:9999/api/v1/tasks/pause?${ids}`, headers: { 'Content-Type': 'application/json', }, onload: function (response) { GM_xmlhttpRequest({ method: 'put', url: `http://127.0.0.1:9999/api/v1/tasks/continue?${ids}`, headers: { 'Content-Type': 'application/json', }, onload: function (response) { } }) } }) } } }) },15000) function testDownLoad() { return fetch('http://127.0.0.1:9999/api/v1/tasks', { method: 'POST', headers: { 'Content-Type': 'application/json' }, }) .then((resp) => resp.json()) .then((res) => { return true; }).catch(e=>{ return false; }) } // Your code here... })();