yanshiqi 发表于 2021-7-24 01:45

腾讯视频m3u8地址解析终究还是来了,顺便再更新一下爱奇艺的解析代码

腾讯视频的解析代码, 包含了太多的个人账号信息, 所以迟迟未能发出来。。。   
于是, 修改了相关代码, 便于更多的小伙伴使用!
原代码里,登陆信息会自动更新,每次使用都不需要设置cookie,   而且间隔几天再用,发现登陆信息依旧有效。。。。   这也是个奇怪的事情。。。   


以下代码是经过处理的,   使用前需要设置cookie.   
我也会教小伙伴们自己手动设置相关信息,以便于以后使用。

以下代码不能单独运行,   需要下载附件, 配合里面的 js文件 以及 加密文件( 放在同一个文件夹里运行 )一起使用!!
运行环境依旧是用到了nodejs,以及 ffmpeg....    经过了前面两个贴子,相信已经有小伙伴懂了

# coding: utf-8
import requests, time, json, subprocess, re


class TXSP:
    def __init__(self, cookie):
      try:
            self.cookie = self.auth_refresh()
      except:
            self.cookie = cookie

    def auth_refresh(self):
      url = 'https://access.video.qq.com/user/auth_refresh'
      params = {
            "vappid": "替换这里",   # 我的"1105**94"
            "vsecret": "替换这里",# 我的 fdf61a6be0aad57132bc5c****ac30145b6cd2c1470b0cfe
            "type": "qq",
            "g_tk": "",
            "g_vstk": "替换这里",       # 我的 2034***571
            "g_actk": "替换这里",       # 16374***17
            "callback": "替换这里",   # jQuery1910682881450***4196_1625677067741
            "_": str(int(time.time() * 1000)),
      }
      with open("cookie.txt", "r") as fp:
            get_cookie = fp.read()
      headers = {
            "authority": "access.video.qq.com",
            "method": "GET",
            "path": "/user/auth_refresh",
            "scheme": "https",
            "accept": "*/*",
            "accept-encoding": "gzip, deflate, br",
            "accept-language": "zh-CN,zh;q=0.9",
            "cookie": get_cookie,
            "referer": "https://v.qq.com/x/page/e3257kqj1la.html",
            "sec-fetch-dest": "script",
            "sec-fetch-mode": "no-cors",
            "sec-fetch-site": "same-site",
            "user-agent": "Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/86.0.4240.198 Safari/537.36",
      }
      resp = requests.get(url=url, params=params, headers=headers)
      text = resp.text
      text_temp = re.compile("(\{.*?\})")
      data = text_temp.findall(text)
      info = json.loads(data)
      set_cookie = "main_login=qq; vqq_access_token={0}; vqq_appid=替换这里; vqq_openid=替换这里; vqq_vuserid={1}; vqq_vusession={2}; vqq_next_refresh_time={3};".format(
            info["access_token"], info["vuserid"], info["vusession"], info["next_refresh_time"])
      with open("cookie.txt", "w", encoding="utf-8") as f:
            f.write(set_cookie)
      return set_cookie

    # get_ckey()这个方法用到了 当前程序所在文件夹下的txsp.js该js文件调用了 ckey.wasm 密钥
    def get_ckey(self, vid):
      # refresh_js(vid)
      guid = ''   # 我的是 cb68b765165403f7***e102cfba61430
      text = "node tx.js {0} {1}".format(vid, guid)
      p = subprocess.run(text, shell=True, stdout=subprocess.PIPE)
      result = p.stdout.decode("utf-8")
      # print(result)
      return result

    def user_info(self, cookie):
      try:
            main_login = re.findall("main_login=(.*?);", cookie)
            openid = re.findall("openid=(.*?);", cookie)
            appid = re.findall("appid=(.*?);", cookie)
            access_token = re.findall("access_token=(.*?);", cookie)
            vuserid = re.findall("vuserid=(.*?);", cookie)
            vusession = re.findall("vusession=(.*?);", cookie)
            return {"main_login": main_login, "openid": openid, "appid": appid, "access_token": access_token,
                  "vuserid": vuserid, "vusession": vusession}
      except:
            return {"main_login": "", "openid": "", "appid": "", "access_token": "", "vuserid": "", "vusession": ""}

    def get_m3u8(self, video_url, vid, ckey):
      url = "https://vd.l.qq.com/proxyhttp"
      headers = {
            "authority": "vd.l.qq.com",
            "method": "POST",
            "path": "/proxyhttp",
            "scheme": "https",
            "accept": "application/json, text/javascript, */*; q=0.01",
            "accept-encoding": "gzip, deflate, br",
            "accept-language": "zh-CN,zh;q=0.9",
            "content-length": "2123",
            "content-type": "text/plain",
            "cookie": self.cookie,
            "origin": "https://v.qq.com",
            "referer": video_url,
            "sec-fetch-dest": "empty",
            "sec-fetch-mode": "cors",
            "sec-fetch-site": "same-site",
            "user-agent": "Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/86.0.4240.198 Safari/537.36",
      }
      t = str(int(time.time()))
      userinfo = self.user_info(self.cookie)
      # print(userinfo)
      if not userinfo["main_login"]:
            print("请重新尝试设置 cookie,只能解析出 高清 视频")
      #cb68b765165403f7c*****cfba61430   6ee0319a367079f6c****d166f0d97d_10201
      vinfoparam = 'spsrt=1&charge=0&defaultfmt=auto&otype=ojson&guid=&flowid=&platform=10201&sdtfrom=v1010&defnpayver=1&appVer=3.5.57&host=v.qq.com&ehost=%s&refer=v.qq.com&sphttps=1&tm=%s&spwm=4&logintoken={"main_login":"%s","openid":"%s","appid":"%s","access_token":"%s","vuserid":"%s","vusession":"%s"}&unid=2798fc67442611eb89cd6c92bf48bcb2&vid=%s&defn=fhd&fhdswitch=0&show1080p=1&isHLS=1&dtype=3&sphls=2&spgzip=1&dlver=2&drm=32&hdcp=0&spau=1&spaudio=15&defsrc=2&encryptVer=9.1&cKey=%s&fp2p=1&spadseg=3' % (
            video_url, t, userinfo["main_login"], userinfo["openid"], userinfo["appid"], userinfo["access_token"],
            userinfo["vuserid"], userinfo["vusession"], vid, ckey.replace("\n", "&"))
      data = {
            "adparam": "pf=in&ad_type=LD|KB|PVL&pf_ex=pc&url=%s" % video_url,
            "buid": "vinfoad",
            "vinfoparam": vinfoparam,
      }
      resp = requests.post(url=url, json=data, headers=headers)
      data = json.loads(resp.content.decode("utf-8"))
      vinfo = data["vinfo"]
      vinfo = json.loads(vinfo)
      video = vinfo["vl"]["vi"]
      title = video["ti"]
      video_url = video["ul"]["ui"]["url"]# json数据中共四个url,这里选第一个,但实测 四个基本是一样的清晰度的。 第四个无法播放!!! 昨天都还可以,今天凉了,不知原因
      print("解析成功 >>> 标题:{0}\tm3u8播放地址:{1}".format(title, video_url))
      return video_url

    def get_vid(self, url):
      vid = re.compile("https://.*/(.*?).html")
      vid = vid.findall(url)
      if vid:
            return vid
      else:
            print("网址解析失败:请将视频完整链接复制后再粘贴!")
            return "-1"

    def play(self, x):
      text = 'ffplay -loglevel repeat+level+warning -i "%s"' % x
      subprocess.call(text, shell=True)

    def page_parser(self, url):
      headers = {
            "authority": "v.qq.com",
            "method": "GET",
            "path": url.replace("https://v.qq.com", ""),
            "scheme": "https",
            "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",
            "accept-encoding": "gzip, deflate, br",
            "accept-language": "zh-CN,zh;q=0.9",
            "cache-control": "max-age=0",
            "cookie": self.cookie,
            "referer": "https://v.qq.com/",
            "sec-fetch-dest": "document",
            "sec-fetch-mode": "navigate",
            "sec-fetch-site": "same-origin",
            "sec-fetch-user": "?1",
            "upgrade-insecure-requests": "1",
            "user-agent": "Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/86.0.4240.198 Safari/537.36",
      }
      resp = requests.get(url=url, headers=headers)
      # <link rel="canonical"/>   若电影有不同语言版本,网址可能不显示 真实 vid 需解析网页
      html = resp.content.decode("utf-8")
      callback_url = re.compile('<link rel="canonical" href="(.*?)" />', re.M | re.S)
      rel_url = callback_url.findall(html)
      if rel_url:
            return rel_url
      else:
            return url

    def start(self):
      video_url = input("请将腾讯视频播放链接粘贴到这里:\n")
      rel_url = self.page_parser(video_url)
      vid = self.get_vid(rel_url)
      m3u8_url = self.get_m3u8(rel_url, vid, self.get_ckey(vid))
      self.play(m3u8_url)


if __name__ == '__main__':
    cookie = input("请先设置腾讯视频cookie: \n")
    txsp = TXSP(cookie)
    while True:
      txsp.start()



以上代码,每次运行需要手动设置cookie,   成品也是依据上面代码生成的。可以正常使用,效果图如下:

http://imgsrc.baidu.com/super/pic/item/b812c8fcc3cec3fd44c15c9f9388d43f86942759.jpg





接下来,就是一劳永逸的事情了, 设置好账号信息后,以后运行,再也不需要设置cookie了!
通过抓包,然后 ctrl + f   搜索:   https://access.video.qq.com/user/auth_refresh
如下图:


http://imgsrc.baidu.com/super/pic/item/3812b31bb051f81908a250fccdb44aed2f73e785.jpg


找到对应的值,替换到原代码里面


url = 'https://access.video.qq.com/user/auth_refresh'
params = {
"vappid": "替换这里", # 我的"1105**94"
"vsecret": "替换这里", # 我的 fdf61a6be0aad57132bc5c****ac30145b6cd2c1470b0cfe
"type": "qq",
"g_tk": "",
"g_vstk": "替换这里", # 我的 2034***571
"g_actk": "替换这里", # 16374***17
"callback": "替换这里", # jQuery1910682881450***4196_1625677067741
"_": str(int(time.time() * 1000)),
}

set_cookie = "main_login=qq; vqq_access_token={0}; vqq_appid=替换这里; vqq_openid=替换这里;
vinfoparam = 'spsrt=1&charge=0&defaultfmt=auto&otype=ojson&guid=替换这里
def get_ckey(self, vid):
guid = '' # 我的是 cb68b765165403f7***e102cfba61430

慢慢试试, 可能有遗漏的需替换的位置
openid guid 的值,都在cookie里面找   

都替换完成后, 修改 初始化方法,以及最后面的 input 去掉,
class TXSP:
def __init__(self):
self.cookie = self.auth_refresh()


不需要传参了。完成自动更新账号信息,获取cookie

最后一步,将同目录下的 cookie.txt打开, 手动把腾讯视频网的cookie粘贴到里面。   
过程写的比较乱,   需要有一定基础的小伙伴去操作,如果有成功的,请留言告诉我下

(PS: 因为没有其他网盘账号,只有百度的, 我下载百度网盘都用别人解析出来的下载链接, 所以对我来说,百度网盘还是挺方便的。望理解)
腾讯视频源码及成品:
链接: https://pan.baidu.com/s/1O6IUQenAaS2g-UnjWbBcTg 提取码: 5yx3

更新一下爱奇艺的源码及成品:   
修改了一个参数, 可以解析出1080P视频, 不需要vip账号。
链接: https://pan.baidu.com/s/1T50uaAXgpLjph-MaQKTtIA 提取码: u7cg

yanshiqi 发表于 2021-8-15 22:46

XMQ 发表于 2021-8-14 08:50
楼主,有没有关于js解密相关方法或者教程,想学习,网上教程太太老了,私

我也是在B站学习的, 搜索:js逆向, 我这几天也都在学,推荐:编程猫志远 第一期,还是能学点东西的。比如webpack 装载器这个,讲的就很好。

yanshiqi 发表于 2021-7-24 01:54

发现还有一个重要事情忘说了,原代码里是用的 qq登陆,   如果是微信登陆的,代码可能不通用,需要改改。   https://access.video.qq.com/user/auth_refresh   根据这个网址的参数修改,每次访问它,都会返回更新过后的cookie信息。

侃遍天下无二人 发表于 2021-7-29 20:14

要不试试把cookie存在map里,提交数据的使用用for-each把cookie全部附加上,这样应该就不用管你咋登陆的了吧?

18519600281 发表于 2021-7-24 07:13

学习学习 感谢分享

a_wei78 发表于 2022-1-6 21:59

多谢分享,还是node整wasm方案。若解说下其ckey 8.1,更好

tofucc 发表于 2022-1-4 15:29

大佬,爱奇艺cookie配置成功,输入地址解析后闪退,不知何故?能否解决?nodejs和ffmpeg都已成功安装。谢谢。

TRB0916 发表于 2021-10-21 20:42

我去,这会不会被企鹅起诉啊

五花小鱼 发表于 2021-8-10 23:35

把芒果和B站的也一起发了吧!!

kissyou 发表于 2021-7-24 08:42

不知道企厂看到了 表情怎么样!:@

Wapj_Wolf 发表于 2021-7-24 07:35

稀罕这种PY纯干货,谢谢大佬分享。

慕容语嫣 发表于 2021-7-24 04:57

学习学习 感谢分享

sjp1ysf01 发表于 2021-7-24 05:17

ATM111 发表于 2021-7-24 05:21

学习了,感谢分享

bingshen 发表于 2021-7-24 05:54

腾讯视频会经常更新,也不知道更新是否与这相关。目前这个可以试试

kabin 发表于 2021-7-24 06:10

厉害,感谢分享 很强大

csmdk 发表于 2021-7-24 06:40

谢谢分享先学习学习

qfnuzlr 发表于 2021-7-24 07:11

学习了有机会实践
页: [1] 2 3 4 5 6 7 8 9 10
查看完整版本: 腾讯视频m3u8地址解析终究还是来了,顺便再更新一下爱奇艺的解析代码