博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Python 一键获取百度网盘提取码
阅读量:5319 次
发布时间:2019-06-14

本文共 4414 字,大约阅读时间需要 14 分钟。

749711-20190608112727407-552859742.gif

该 GIF 图来自于官网,文末有给出链接。

描述

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

实现

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

v1

"""Author:hippieZhouDate:20190608Description: Get BaiDuYun shared link's Code """import argparseimport reimport requestsimport jsonimport timeVERSION = "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 Truedef 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 parserdef 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()

运行效果如下图所示:

749711-20190608112448424-415763285.png

v2

"""Author:hippieZhouDate:20190608Description: Get BaiDuYun shared link's Code """import argparseimport timeimport reimport requestsfrom datetime import datetimeimport 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"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(╥﹏╥)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 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)        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()

运行效果如下图所示:

749711-20190608112518065-915634393.png

总结

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

如果你觉得上述代码不错的话,欢迎访问对应的仓库地址: 进行 starforkfollow

相关参考

转载于:https://www.cnblogs.com/hippieZhou/p/10990237.html

你可能感兴趣的文章
MySql | 常用操作总结
查看>>
json和Jsonp 使用总结(1)
查看>>
Synchronized之二:synchronized的实现原理
查看>>
添加dom节点及优化
查看>>
J2EE Form-based Authentication
查看>>
2018-2019-2 网络对抗技术 20165301 Exp 8 Web基础
查看>>
nginx 配置路由规则转发配置记录
查看>>
Java静态内部类
查看>>
jquery实现文字向上滚动
查看>>
正在执行的sql
查看>>
CMDB资产采集
查看>>
Linux 常见的trouble shooting故障排错
查看>>
物联网操作系统的概念和特点
查看>>
Hexo站点之域名配置【2】
查看>>
itsdangerous模块
查看>>
C++ 简单字符串加解密(转载)
查看>>
wireshark
查看>>
攻防工具
查看>>
20. 有效的括号
查看>>
公司级平台-IProgram-DAL
查看>>