亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

Python 一鍵獲取百度網盤提取碼的方法

系統 1639 0

該 GIF 圖來自于官網,文末有給出鏈接。

描述

依托于百度網盤巨大的的云存儲空間,絕大數人會習慣性的將一些資料什么的存儲到上面,但是有的私密鏈接需要提取碼,但是讓每個想下載私密資源的人記住每一個提取碼顯然是不現實的。這個時候,云盤萬能鑰匙 誕生了,我們通過安裝相應的瀏覽器插件就可以自動獲獲取相應鏈接的提取碼。我在 Github 上看了一下,有 Web JS 版的, python 版的貌似還沒有找到,所以我參照了JS 版本和官網的請求接口寫了兩種方式的獲取腳本。

實現

下述兩種方式的具體實現就不做代碼解釋了,思路都是一樣,通過請求接口,拿到數據,然后返回即可。

v1

            
"""
Author:hippieZhou
Date:20190608
Description: Get BaiDuYun shared link's Code 
"""
import argparse
import re
import requests
import json
import time

VERSION = "VERSION 1.0.0"


def checkUrl(url: str) -> str:
  m1 = re.match(
    "https?:\/\/pan\.baidu\.com\/s\/1([a-zA-Z0-9_\-]{5,22})", url)
  m2 = re.match(
    "https?:\/\/pan\.baidu\.com\/share\/init\?surl=([a-zA-Z0-9_\-]{5,22})", url)
  if not m1 and not m2:
    print("參數不合法")
    return False
  else:
    return True


def getKey(url: str) -> bool:
  if checkUrl(url):
    try:
      req = requests.get(f"https://node.pnote.net/public/pan?url={url}")
      code = req.status_code
      if code == 200:
        data = dict(json.loads(req.text))
        status = data.get("status", False)
        if status:
          return data.get("access_code", "未能查詢到該鏈接的提取碼,可能原因是:該鏈接不需要提取碼或已過期")
        else:
          return data.get("messages", "為能查詢到提取碼")
      elif code == 404:
        return "不存在該鏈接的記錄"
    except Exception as e:
      return f"請求服務器失敗,錯誤代碼:[code]"


def get_parser():
  parser = argparse.ArgumentParser()
  parser.description = "百度網盤提取碼一鍵獲取器"
  parser.add_argument('urls', metavar="urls", type=str, nargs="*",
            help='設置要獲取提取碼的鏈接(多個鏈接請用空格分隔)')
  parser.add_argument('-v', '--version', action='store_true',
            help='版本號')
  return parser


def command_line_runner():
  parser = get_parser()
  args = vars(parser.parse_args())
  if args['version']:
    print(VERSION)
    return

  s_time = time.time()
  if len(args['urls']) > 1:
    for item in args["urls"][1:]:
      print(f"{item}:\r\n\t{getKey(item)}")
    e_time = time.time()
    print(f"\n\n操作完畢,總耗時:{e_time-s_time} 秒")


def main():
  command_line_runner()


if __name__ == "__main__":
  main()


          

運行效果如下圖所示:

Python 一鍵獲取百度網盤提取碼的方法_第1張圖片

v2

            
"""
Author:hippieZhou
Date:20190608
Description: Get BaiDuYun shared link's Code 
"""

import argparse
import time
import re
import requests
from datetime import datetime
import json

accessKey = "4fxNbkKKJX2pAm3b8AEu2zT5d2MbqGbD"
clientVersion = "web-client"


def getPid(url: str) -> str:
  matches = re.match(
    "https?:\/\/pan\.baidu\.com\/s\/1([a-zA-Z0-9_\-]{5,22})", url)
  return matches[1] if matches else None


def getUuid(pid: str) -> str:
  return f"BDY-{pid}"


def getKey(url: str) -> str:
  pid = getPid(url)
  uuid = getUuid(pid)
  headers = {
    "type": "GET",
    "data": '',
    "dataType": "json"
  }
  url = f"http://ypsuperkey.meek.com.cn/api/items/{uuid}?access_key={accessKey}&client_version={clientVersion}&{datetime.utcnow()}"
  try:
    req = requests.get(url, headers=headers)
    code = req.status_code
    if code == 200:
      data = json.loads(req.text)
      accessCode = data.get("access_code", None)
      return "沒找到提取密碼,o(?i?n?i)o" if (accessCode == "undefined" or accessCode == None or accessCode == "") else accessCode
    elif code == 400:
      return " 服務器不理解請求的語法"
    elif code == 404:
      return "不存在該鏈接的記錄"
    else:
      return f"請求服務器失敗,錯誤代碼:[code]"
  except Exception as e:
    return e


def get_parser():
  parser = argparse.ArgumentParser()
  parser.description = "百度網盤提取碼一鍵獲取器"
  parser.add_argument('urls', metavar="urls", type=str, nargs="*",
            help='設置要獲取提取碼的鏈接(多個鏈接請用空格分隔)')
  parser.add_argument('-v', '--version', action='store_true',
            help='版本號')
  return parser


def command_line_runner():
  parser = get_parser()
  args = vars(parser.parse_args())
  if args['version']:
    print(VERSION)
    return

  s_time = time.time()
  if len(args['urls']) > 1:
    for item in args["urls"][1:]:
      print(f"{item}:\r\n\t{getKey(item)}")
    e_time = time.time()
    print(f"\n\n操作完畢,總耗時:{e_time-s_time} 秒")


def main():
  command_line_runner()


if __name__ == "__main__":
  main()


          

運行效果如下圖所示:

Python 一鍵獲取百度網盤提取碼的方法_第2張圖片

總結

v1 版本和 v2 版本是通過請求不同的接口方式來實現的, v2 接口的數據要相對更準確一些。具體可查閱具體的代碼實現。

如果你覺得上述代碼不錯的話,歡迎訪問對應的倉庫地址: baidupankey 進行 star 、fork 和 follow。

相關參考

  • 云盤萬能鑰匙
  • JS 版

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 亚洲国产一区在线 | 国产精品日韩一区二区三区 | 综合久久久久久久综合网 | www.亚洲成人.com | 色婷婷综合久久久久中文一区二区 | 亚洲精品久久久久综合中文字幕 | 亚洲第一成人在线 | 中文日韩欧美 | 国产一区二区在线播放 | 寡妇一级a毛片免费播放 | 久操视频在线播放 | 国内国产精品天干天干 | 亚洲国产精品激情在线观看 | 日本天天谢天天要天天爱 | 天天操精品 | 手机在线中文字幕 | 伊人久久免费视频 | 狠狠色噜噜狠狠狠狠97老肥女 | 亚洲人成在线观看 | 狠狠的干狠狠的操 | 亚洲欧美大片 | 久久精品免费全国观看国产 | 四虎在线网站 | 日韩精品特黄毛片免费看 | 九九热精品在线 | 国产精品久久久久免费视频 | 四虎网址换成什么了2021 | 欧美网站www | 一级毛片一级毛片一级级毛片 | 国产精品高清在线观看 | 亚洲天堂国产 | 亚洲阿v天堂在线观看2017 | 米奇精品一区二区三区 | 亚洲一区二区三区久久 | 大伊香蕉在线精品不卡视频 | 亚洲麻豆精品 | 亚洲最大成人 | 国产精品夜色一区二区三区 | 国内在线精品 | 欧美在线一区二区三区 | 国产精品永久免费自在线观看 |