使用Python一键获取百度网盘提取码

编程入门 行业动态 更新时间:2024-10-25 20:28:56

使用Python<a href=https://www.elefans.com/category/jswz/34/1767003.html style=一键获取百度网盘提取码"/>

使用Python一键获取百度网盘提取码

描述
依托于百度网盘巨大的的云存储空间,绝大数人会习惯性的将一些资料什么的存储到上面,但是有的私密链接需要提取码,但是让每个想下载私密资源的人记住每一个提取码显然是不现实的。这个时候,云盘万能钥匙 诞生了,我们通过安装相应的浏览器插件就可以自动获获取相应链接的提取码。我在 Github 上看了一下,有 Web JS 版的, python 版的貌似还没有找到,所以我参照了JS 版本和官网的请求接口写了两种方式的获取脚本。

实现

下述两种方式的具体实现就不做代码解释了,思路都是一样,通过请求接口,拿到数据,然后返回即可

v1

import argparse
import re
import requests
import json
import time
'''
遇到python不懂的问题,可以加Python学习交流群:1004391443一起学习交流,群文件还有零基础入门的学习资料
'''
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 Falseelse:return Truedef getKey(url: str) -> bool:if checkUrl(url):try:req = requests.get(f"={url}")code = req.status_codeif 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 parserdef command_line_runner():parser = get_parser()args = vars(parser.parse_args())if args['version']:print(VERSION)returns_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()

v2

-----------------------------------------------------
注:我这有个学习基地,里面有很多学习资料,感兴趣的+Q群:895 797 751
-----------------------------------------------------
'''
遇到python不懂的问题,可以加Python学习交流群:1004391443一起学习交流,群文件还有零基础入门的学习资料
'''
import argparse
import time
import re
import requests
from datetime import datetime
import jsonaccessKey = "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 Nonedef 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"/{uuid}?access_key={accessKey}&client_version={clientVersion}&{datetime.utcnow()}"try:req = requests.get(url, headers=headers)code = req.status_codeif code == 200:data = json.loads(req.text)accessCode = data.get("access_code", None)return "没找到提取密码,o(╥﹏╥)o" if (accessCode == "undefined" or accessCode == None or accessCode == "") else accessCodeelif code == 400:return " 服务器不理解请求的语法"elif code == 404:return "不存在该链接的记录"else:return f"请求服务器失败,错误代码:{code}"except Exception as e:return edef 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 parserdef command_line_runner():parser = get_parser()args = vars(parser.parse_args())if args['version']:print(VERSION)returns_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()

总结
v1 版本和 v2 版本是通过请求不同的接口方式来实现的, v2 接口的数据要相对更准确一些。具体可查阅具体的代码实现。

更多推荐

使用Python一键获取百度网盘提取码

本文发布于:2023-07-28 22:04:50,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1335257.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:一键   百度网   Python

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!