• 欢迎访问1024小神,一个只会Python的程序猿不是一个好司机
  • 有什么想对我说的可以在留言板里给我留言哦~
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏1024小神吧

使用Python下载m3u8视频实践,完美

Python 1024小神 1个月前 (09-25) 76次浏览 1个评论

目的就是搞清楚这类视频的原理是什么,方便为后续的爬虫坐准备:

import requests
import re
from Crypto.Cipher import AES


def m3u8(url):
    header = {
        'User-Agent': 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_2) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/71.0.3578.98 Safari/537.36'
    }
    # requests得到m3u8文件内容
    content = requests.get(url, headers=header).text
    if "#EXTM3U" not in content:
        print("这不是一个m3u8的视频链接!")
        return False
    if "EXT-X-KEY" not in content:
        print("没有加密")
        return down_nokey(url, content)
    else:
        print("视频加密了")
        return down_havekay(url, content)

def down_havekay(url, content):
    header = {
        'User-Agent': 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_2) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/71.0.3578.98 Safari/537.36'
    }
    # 下载加密的视频
    # 使用re正则得到key和视频地址
    jiami = re.findall('#EXT-X-KEY:(.*)\n', content)
    key = re.findall('URI="(.*)"', jiami[0])
    # 得到每一个ts视频链接
    tslist = re.findall('EXTINF:(.*),\n(.*)\n#', content)
    newlist = []
    for i in tslist:
        newlist.append(i[1])

    # 先获取URL/后的后缀,再替换为空
    urlkey = url.split('/')[-1]
    url2 = url.replace(urlkey, '')  # 这里为得到url地址的前面部分,为后面key的链接和视频链接拼接使用

    # 得到key的链接并请求得到加密的key值
    keyurl = url2 + key[0]
    keycontent = requests.get(keyurl, headers=header).text

    # 得到每一个完整视频的链接地址
    tslisturl = []
    for i in newlist:
        tsurl = url2 + i
        tslisturl.append(tsurl)

    # 得到解密方法,这里要导入第三方库  pycrypto
    # 这里有一个问题,安装pycrypto成功后,导入from Crypto.Cipher import AES报错
    # 找到使用python环境的文件夹,在Lib文件夹下有一个 site-packages 文件夹,里面是我们环境安装的包。
    # 找到一个crypto文件夹,打开可以看到 Cipher文件夹,此时我们将 crypto文件夹改为 Crypto 即可使用了
    cryptor = AES.new(keycontent, AES.MODE_CBC, keycontent)

    # for循环获取视频文件
    print(f"一共获取到{len(newlist)}段ts视频链接")
    for i in tslisturl:
        print(f"正在解析{i}的ts视频链接")
        res = requests.get(i, header)
        # 使用解密方法解密得到的视频文件
        cont = cryptor.decrypt(res.content)
        # 以追加的形式保存为mp4文件
        with open('xx.mp4', 'ab+') as f:
            f.write(cont)
    return True

def down_nokey(url, content):
    header = {
        'User-Agent': 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_2) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/71.0.3578.98 Safari/537.36',
        "Referer":"https://f0821.wonderfulday25.live/"
    }
    # 下载未加密的视频
    head_url = url.split("m3u8/")[1].split("/")[0]
    # 得到每一个ts视频链接
    tslist = re.findall('EXTINF:(.*),\n(.*)\n#', content)
    newlist = []
    for i in tslist:
        tsurl = i[1]
        if not tsurl.startswith("http"):
            tsurl = f"https://ccn.killcovid2021.com//m3u8/{head_url}/" + tsurl
        newlist.append(tsurl)
    # for循环获取视频文件
    print(f"一共获取到{len(newlist)}段ts视频链接")
    for i in newlist:
        print(f"正在解析{i}的ts视频链接")
        res = requests.get(i, header)
        # 以追加的形式保存为mp4文件
        with open('xx2.mp4', 'ab+') as f:
            f.write(res.content)
    return True

if __name__ == '__main__':
    # 未加密
    # url = "https://play.com/m/t/PpOeMVEk3d4zxI8lqQDv30xD-5HHn44MCki3utgBVT9mmA67F60cFfyP8AFHbtYN_AKwKOAlyOgDlfk59pGrJtey-sDFUpjAQfhS2AIbuifDuesEDiYevBYAD8FZvcQn.m3u8"
    # 91未加密
    # url = "https://ccn.killcovid2021.com//m3u8/529689/529689.m3u8"
    url = "https://ccn.killcovid2021.com//m3u8/529802/529802.m3u8"
    pd = m3u8(url)
    if pd:
        print('视频下载完成!')

下载成功后的视频:


如有失效,请留言告知丨转载请注明原文链接:使用Python下载m3u8视频实践,完美
点赞 (0)

您必须 登录 才能发表评论!

(1)个小伙伴在吐槽
  1. starlz
    之前一直用手机版idm
    2021-09-25 22:37