吾爱破解 - 52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 5781|回复: 37
收起左侧

[Python 转载] 【更新】多线程下载低端影视视频

   关闭 [复制链接]
话痨司机啊 发表于 2022-8-11 19:50
本帖最后由 话痨司机啊 于 2022-9-7 16:27 编辑

同目录 新建一个txt叫ddrk_address.txt ,然后粘贴地址,例如:https://ddys.tv/fall/
【成品链接】: https://pan.baidu.com/s/1yevkncLAEkHTgku6nOczpw?pwd=3qg9 提取码: 3qg9
主页:https://ddys.tv
【2022-9-5更新】 验证成功
11.png

分析软件:fiddler、chrome浏览器

1.jpg

[Python] 纯文本查看 复制代码
# ddrk 低端影视下载

import base64
import re
import time
from datetime import datetime
from pathlib import Path
from urllib import parse

import requests
from Crypto.Cipher import AES
from Crypto.Util.Padding import pad
from loguru import logger

from python_idm import download

logger.add('ddrk_log.log')

headers = {
    'Host': 'ddys.tv',
    'Connection': 'keep-alive',
    'sec-ch-ua': '^\\^Chromium^\\^;v=^\\^104^\\^, ^\\^',
    'sec-ch-ua-mobile': '?0',
    'sec-ch-ua-platform': '^\\^Windows^\\^',
    'DNT': '1',
    'Upgrade-Insecure-Requests': '1',
    'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/104.0.0.0 Safari/537.36',
    'Accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9',
    'Sec-Fetch-Site': 'same-origin',
    'Sec-Fetch-Mode': 'navigate',
    'Sec-Fetch-User': '?1',
    'Sec-Fetch-Dest': 'document',
    'Referer': 'https://ddys.tv/',
    'Accept-Encoding': 'gzip, deflate, br',
    'Accept-Language': 'zh-CN,zh;q=0.9',
}

def encrpyt_string(paths,key):
    """ddrk加密函数"""
    if len(key)>16:
        return key
    key = key.encode('utf8')
    iv = '1529076118276120'.encode('utf8')
    time_tuple = datetime.now().timetuple()
    expires = int(time.mktime(time_tuple))*1000 + 600000
    text = '{"path":"' + f'{paths}'+ f'","expire":{expires}' + '}'
    text = pad(text.encode('utf8'),64,'pkcs7')
    cryptor = AES.new(key=key,mode=AES.MODE_CBC,iv=iv)
    ciphertext = cryptor.encrypt(text)
    encryption_result = parse.quote(base64.b64encode(ciphertext).decode('utf8'))
    return encryption_result

@logger.catch
def get_path(res):
    '''获取加密参数'''
    result = re.findall(r'"tracks":(.*?)}</script>',res.text,re.S)[0]
    result = result.replace('\n','')
    title = re.findall(r'<title>(.*?)</title>',res.text)[0]
    datas =  [(index,i.get('src0').replace(r'\/','/'),i.get('src1')) for index,i in enumerate(eval(result),start=1)]
    return title,datas

@logger.catch
def get_mp4_url(session,ids):
    '''获取MP4_URL'''
    base_url = f'https://ddys.tv/getvddr/video?id={ids}&dim=1080P+&type=mix'
    # cookies={'X_CACHE_KEY':'df43ecf509ad4237f04d9059dc1cc4d9'}
    jsons = session.get(base_url)
    logger.info(jsons.json())
    return jsons.json().get('url')

def main(url):
    '''主函数'''
    session = requests.Session()
    session.headers.clear()
    session.headers.update(headers) # 注意header顺序,顺序不对,请求不到数据
    response = session.get(url)
    title,datas = get_path(response)
    if len(datas)>1:
        for index,path,key in datas:
            mp4_url = get_mp4_url(session,encrpyt_string(path,key))
            titles = title 
            titles = titles + f'_第{index}集' + '.mp4'
            logger.info(f'开始下载{titles},链接为:{mp4_url}')
            if mp4_url is not None:
                download(mp4_url,thread_count=24,save_name=title)
            else:
                logger.warning('未获取到MP4URL')
    else:
        mp4_url = get_mp4_url(session,encrpyt_string(datas[0][1],datas[0][2]))
        title = title + '.mp4'
        logger.info(f'开始下载 -> {title},链接为:{mp4_url}')
        if mp4_url is not None:
            download(mp4_url,thread_count=24,save_name=title)
        else:
            logger.warning('未获取到MP4URL')
        
if __name__ == '__main__':
    with open(Path('.').absolute().joinpath('ddrk_address.txt'),'r',encoding='utf8') as f:
        urls = f.readlines()
    for url in urls:
    # url = "https://ddrk.me/school-tales-the-series/"        
        main(url)


[Python] 纯文本查看 复制代码
from concurrent.futures import ThreadPoolExecutor, as_completed
import requests
from itertools import tee
from alive_progress import alive_bar

def pairwise(iterable):
    '''转换'''
    # pairwise('ABCDEFG') --> AB BC CD DE EF FG
    a, b = tee(iterable)
    next(b, None)
    return zip(a, b)

def calc_divisional_range(res,threads_count):
    '''分区下载'''
    capacity = int(res.headers['Content-Length'])
    remainder = int(capacity%threads_count)
    singular = int((capacity - remainder)/threads_count)
    url_range = list(pairwise((range(0,capacity - remainder + singular,singular))))
    url_range[-1] = (url_range[-1][0],capacity -1)
    return url_range

def range_download(url,save_name, s_pos, e_pos,proxies=None):
    '''下载函数'''
    headers = {"Range": f"bytes={s_pos}-{e_pos}"}
    res = requests.get(url, headers=headers, stream=True,proxies=proxies)
    with open(save_name, "rb+") as f:
        f.seek(s_pos)
        for chunk in res.iter_content(chunk_size=64*1024):
            if chunk:
                f.write(chunk)

def download(url,thread_count,save_name=None,proxies=None):
    '''多线程调用下载'''
    # url,thread_count = 'http://yue.cmvideo.cn:8080/depository_yqv/asset/zhengshi/5102/598/709/5102598709/media/5102598709_5010999563_56.mp4',16
    if save_name is None:
        save_name = url.split('/')[-1]
    print(save_name,'下载中……')
    res = requests.head(url,proxies=proxies)
    divisional_ranges = calc_divisional_range(res,thread_count)
    with open(save_name, "wb") as f:
        pass
    with ThreadPoolExecutor(max_workers=thread_count) as p,alive_bar(len(divisional_ranges)+1) as bar:
        futures = []
        for s_pos, e_pos in divisional_ranges:
            # print(s_pos, e_pos)
            futures.append(p.submit(range_download,url,save_name, s_pos, e_pos,proxies=proxies))
        # 等待所有任务执行完毕
        for f in as_completed(futures):
            if f.done():
                bar()
    print(save_name,'下载完成!')

if __name__ == '__main__':
    url = input('输入下载链接:')
    thread_count = 16
    download(url,thread_count)

JS逆向关键代码如下:

123123123.png

免费评分

参与人数 5吾爱币 +13 热心值 +5 收起 理由
base + 1 + 1 谢谢@Thanks!
苏紫方璇 + 7 + 1 欢迎分析讨论交流,吾爱破解论坛有你更精彩!
MyModHeaven + 1 + 1 我很赞同!
xiaomi1998 + 1 + 1 用心讨论,共获提升!
漁滒 + 3 + 1 我很赞同!

查看全部评分

本帖被以下淘专辑推荐:

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

 楼主| 话痨司机啊 发表于 2022-8-12 11:01
本帖最后由 话痨司机啊 于 2022-8-12 11:13 编辑
ookk 发表于 2022-8-12 09:24
https://ddrk.me/wo-ai-wo-jia/

2022-08-12 09:22:53.397 | INFO     | __main__:get_mp4_url:69 - {'er ...

因为之前都是Postman测试的请求结果都通过了,然后直接写代码没咋测试(尴尬),看了眼逻辑对就直接上传了,这块源码以为不需要验证呢,哈哈哈!!已经重新修改源码了,已经下源码的自己改一下68行
1.png
ookk 发表于 2022-8-12 09:24
https://ddrk.me/wo-ai-wo-jia/

2022-08-12 09:22:53.397 | INFO     | __main__:get_mp4_url:69 - {'err': 'error2'}
2022-08-12 09:22:53.398 | INFO     | __main__:main:84 - 开始下载我爱我家 (120集全) - 低端影视_第1集.mp4,链接为:None
2022-08-12 09:22:53.399 | WARNING  | __main__:main:88 - 未获取到MP4URL
modesty88 发表于 2022-8-11 19:54
 楼主| 话痨司机啊 发表于 2022-8-11 19:55

en ,对滴
ciker_li 发表于 2022-8-11 20:16
感谢分享
漁滒 发表于 2022-8-11 20:43
ddrk的字幕有一个pako的解压,这个有python的方案可以解决吗?
 楼主| 话痨司机啊 发表于 2022-8-11 20:46
漁滒 发表于 2022-8-11 20:43
ddrk的字幕有一个pako的解压,这个有python的方案可以解决吗?

下载就是带字幕的吧
漁滒 发表于 2022-8-11 20:47
话痨司机啊 发表于 2022-8-11 20:46
下载就是带字幕的吧

ddrk是有外挂字幕的
漁滒 发表于 2022-8-11 22:11
hecoter 发表于 2022-8-11 21:05
时代变了,现在下载就是mp4,没以前这么麻烦了

原来是这样,好久没关注过这个网站了
 楼主| 话痨司机啊 发表于 2022-8-11 22:37
本帖最后由 话痨司机啊 于 2022-8-11 22:41 编辑
漁滒 发表于 2022-8-11 20:43
ddrk的字幕有一个pako的解压,这个有python的方案可以解决吗?

pako解压应该也行吧,是类似大众点评的点评字符解密拼接?大众点评我记得好像用棋盘算法能解
ookk 发表于 2022-8-12 00:43
是不是需要登录后的cookie才行呀  
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

返回列表

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2025-1-11 13:01

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表