Greasy Fork is available in English.

百度网盘SVIP解析不限速下载-KK加速

加速无止境!一款百度网盘SVIP解析加速下载脚本,下载速度可达10M-50M/S,支持谷歌,火狐,360,IE等浏览器!

// ==UserScript==
// @name         百度网盘SVIP解析不限速下载-KK加速
// @namespace    http://tampermonkey.net/
// @version      1.6
// @description  加速无止境!一款百度网盘SVIP解析加速下载脚本,下载速度可达10M-50M/S,支持谷歌,火狐,360,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: 'KKdown',
  };
  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...
})();