zoukankan      html  css  js  c++  java
  • Python 一键获取百度网盘提取码

    该 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}:
    	{getKey(item)}")
            e_time = time.time()
            print(f"
    
    操作完毕,总耗时:{e_time-s_time} 秒")
    
    
    def main():
        command_line_runner()
    
    
    if __name__ == "__main__":
        main()
    

    运行效果如下图所示:

    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(╥﹏╥)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}:
    	{getKey(item)}")
            e_time = time.time()
            print(f"
    
    操作完毕,总耗时:{e_time-s_time} 秒")
    
    
    def main():
        command_line_runner()
    
    
    if __name__ == "__main__":
        main()
    

    运行效果如下图所示:

    总结

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

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

    相关参考

  • 相关阅读:
    leetcode Remove Linked List Elements
    leetcode Word Pattern
    leetcode Isomorphic Strings
    leetcode Valid Parentheses
    leetcode Remove Nth Node From End of List
    leetcode Contains Duplicate II
    leetcode Rectangle Area
    leetcode Length of Last Word
    leetcode Valid Sudoku
    leetcode Reverse Bits
  • 原文地址:https://www.cnblogs.com/hippieZhou/p/10990237.html
Copyright © 2011-2022 走看看