前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >记一次某度wangpan 无xiansu下载地址解析站的分析及实现

记一次某度wangpan 无xiansu下载地址解析站的分析及实现

原创
作者头像
拉灯的小手
发布2022-11-12 22:44:32
36500
代码可运行
发布2022-11-12 22:44:32
举报
运行总次数:0
代码可运行

本文所有教程及源码、软件仅为技术研究。不涉及计算机信息系统功能的删除、修改、增加、干扰,更不会影响计算机信息系统的正常运行。不得将代码用于非法用途,如侵立删!


记一次某度wangpan 无xiansu下载地址解析站的分析及实现

操作环境

  • win10 、 mac
  • Python3.9
  • requests、lxml
  • Charles

分析

解析站:

aHR0cHM6Ly93d3cua2Vsb25nd28uY29tL1Jlc291cmNlX2Z1bmN0aW9uL3Bhbi9iYWlkdS8=

在这里插入图片描述
在这里插入图片描述

经分析研究,发现想要拿到无限速下载地址共需两步:

1.写入wangpan地址,提取出解析所需的参数
在这里插入图片描述
在这里插入图片描述

就是一个get接口,传入网盘地址拿到相应参数

在这里插入图片描述
在这里插入图片描述
2.解析不限速下载地址

根据第一步中提取的参数,构造post请求,即可解析出下载地址

在这里插入图片描述
在这里插入图片描述

脚本实现

1.提取出解析所需的参数

代码语言:python
代码运行次数:0
复制
def get_level_one(url, pwd=None):
    """
    一级解析
    url:网盘地址
    pwd:网盘密码
    """
    print(f'地址:{url} 一级参数提取中')
    # 解析接口
    params = {
        'url': url,
        'pwd': pwd
    }
    # 提取二次解析所需参数
    res = requests.get(jx_ul, params=params)
    root = etree.HTML(res.content)
    download_params = root.xpath('//*[@id="bd_list"]/div[2]/div/a/@href')
    parameter = []
    n = download_params[0].split(',')
    for i in n:
        if "javascript:downfile(" in i:
            i = i.replace('javascript:downfile(', '')
        if ')' in i:
            i = i.replace(")", '')
        parameter.append(i)
    print(parameter)
    print("成功提取一级解析参数")
    return parameter

2.提取下载链接

代码语言:python
代码运行次数:0
复制
def get_level_two(parameter):
    # 二级解析
    print(f'下载地址解析中,需等待2-5秒')
    headers = {
        'Connection': 'keep-alive',
        'Content-Length': '264',
        'sec-ch-ua': '"Microsoft Edge";v="107", "Chromium";v="107","Not=A?Brand";v="24"',
        'Accept': '*/*',
        'Content-Type': 'application/x-www-form-urlencoded; charset=UTF-8',
        'X-Requested-With': 'XMLHttpRequest',
        'sec-ch-ua-mobile': '?0',
        'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/107.0.0.0 Safari/537.36 Edg/107.0.1418.35',
        'sec-ch-ua-platform': '"Windows"',
        'Sec-Fetch-Site': 'same-origin',
        'Sec-Fetch-Mode': 'cors',
        'Sec-Fetch-Dest': 'empty',
        'Accept-Encoding': 'gzip, deflate, br',
        'Accept-Language': 'zh-CN,zh;q=0.9,en;q=0.8,en-GB;q=0.7,en-US;q=0.6,en-GB-oxendict;q=0.5',
        'Cookie': 'session_prefix=a5a4be6cf29eaac32b0c2aa55750daa7; Hm_lvt_f749697bf30790443314f1111033dc5c=1667395320,1667737450,1667818866,1667870341',
    }
    downfile = {
        'fs_id': parameter[0].replace("'", ''),
        'sign': parameter[1].replace("'", ''),
        'timestamp': parameter[2].replace("'", ''),
        'randsk': parameter[3].replace("'", ''),
        'share_id': parameter[4].replace("'", ''),
        'bdstoken': parameter[5].replace("'", ''),
        'filesize': parameter[6].replace("'", ''),
        'uk': parameter[7].replace("'", ''),
        'md5': parameter[8].replace("'", ''),
    }
    response = requests.post(ask_download, headers=headers, data=downfile)
    # 提取下载链接
    # 提取二次解析所需参数
    root = etree.HTML(response.text)
    params = root.xpath('//div[@class="q-topic-item"]/div/a[1]/@href')
    if params:
        href = params[0].replace("javascript:file_url_copy('", '').replace("')", '')
    else:
        href = '提取失败!'
    print(f'下载地址:{href}')

效果

请添加图片描述
请添加图片描述

资源下载

https://download.csdn.net/download/qq_38154948/86978290


本文仅供学习交流使用,如侵立删!


原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 记一次某度wangpan 无xiansu下载地址解析站的分析及实现
    • 操作环境
      • 分析
        • 解析站:
        • 1.写入wangpan地址,提取出解析所需的参数
        • 2.解析不限速下载地址
    • 脚本实现
      • 1.提取出解析所需的参数
        • 2.提取下载链接
        • 效果
        • 资源下载
        领券
        问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
        http://www.vxiaotou.com