在您安装前,Greasy Fork 希望您知道此脚本包含可能不受欢迎的功能,也许会帮助脚本作者获利,而不能给你带来任何收益。
这个脚本会在你访问的网站插入广告。
你只有在参与某些事后才能使用脚本的全部功能,如加入某群组、订阅某频道或在某页点赞等。
作者从这份脚本获得佣金,例如透过改写链接或提供优惠券代码以包含推荐或附属代码。
3G以下文件(不支持文件夹解析及批量解析)解析网盘直链下载地址,配合 Gopeed 实现不限速下载
目前为
// ==UserScript== // @name 文武解析-Gopeed网盘直链获取助手 // @namespace http://tampermonkey.net/ // @version 1.0 // @description 3G以下文件(不支持文件夹解析及批量解析)解析网盘直链下载地址,配合 Gopeed 实现不限速下载 // @author dongyubin // @icon data:image/gif;base64,R0lGODlhAQABAAAAACH5BAEKAAEALAAAAAABAAEAAAICTAEAOw== // @license MIT // @icon https://fk.wwkejishe.top/uploads/images/6e798005b00ce678782af4e6931f4374.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 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 // @antifeature ads // @antifeature membership // @antifeature referral-link // ==/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: #6800ff;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: #fc5531;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: #06a7ff;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://cdn.wwkejishe.top/wp-cdn-02/2024/202411171346351.webp" 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;">插件解析限制 2 次</div> <div>下载器一定要配置好 User-Agent 和端口: <a style="color:green;" target="_blank" href="https://flowus.cn/share/c68e3c55-67e5-460f-b937-7727e0378a34?code=BCRWJL">点击查看下载器配置教程说明</a></div> <div>不限次数 PC 网页稳定版: <a style="color:green;" target="_blank" href="https://pandown.mlover.site/">点击前往</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 canDown = await testDownLoad(); if (!canDown) { layer.close(openLayer); swal({ title: "下载Gopeed加速器", text: '请先安装Gopeed下载器并打开运行,点击按钮下载Gopeed加速下载器。', icon: 'warning', type: "warning", showCancelButton: true, showConfirmButton: true, confirmButtonText: '点击下载Gopeed', confirmButtonColor: "#dd6b55", }).then(function () { window.open('https://pan.quark.cn/s/0b2e9c6e94b0'); }); $('#parse').html('<p>解析</p>'); return; } share_one_baidu(openLayer, 1234); }); }, }); }); }); 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://aifenxiang.net.cn:8081', bd_password: '1234', title_name: '文武解析', }; function share_one_baidu(openLayer, code) { 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/getCodeNum', { method: 'POST', headers: { 'Content-Type': 'application/json', }, body: JSON.stringify({ code: code, userKey: 'main', fsId: select[0], version: '1.1.2', }), }) .then((resp) => resp.json()) .then((res) => { let laysermsg = layer.msg('正在解析中', { icon: 6, time: 10000, // 7秒后自动关闭 }); if (res.code == 200) { config.code = code; 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.alert('解析次数已达上限,不限次数稳定版!', { title: '提示', }, function () { window.open('https://pandown.mlover.site'); }); }, 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({ text: '文件大于 3G,插件暂不支持下载,请前往 PC 网页版下载!', icon: '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); console.log(responseData); if (responseData.code !== 200) { layer.close(openLayer); layer.close(laysermsg); swal({ text: responseData.msg, icon: 'warning', }); } else { layer.close(laysermsg); $('#parse').html('<p>解析</p>'); if (responseData.data.vip) { config.url = responseData.data.data[0].url; } else { config.url = responseData.data.data.urls[0].url; } 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 }, opt: { extra: { connections: 256, } } }), }).then((resp) => resp.json()) .then((res) => { layer.alert(`${item.server_filename}开始下载,请打开下载器查看!`); }).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; }) } })();