腾讯视频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
XMQ 发表于 2021-8-14 08:50
楼主,有没有关于js解密相关方法或者教程,想学习,网上教程太太老了,私
我也是在B站学习的, 搜索:js逆向, 我这几天也都在学,推荐:编程猫志远 第一期,还是能学点东西的。比如webpack 装载器这个,讲的就很好。 发现还有一个重要事情忘说了,原代码里是用的 qq登陆, 如果是微信登陆的,代码可能不通用,需要改改。 https://access.video.qq.com/user/auth_refresh 根据这个网址的参数修改,每次访问它,都会返回更新过后的cookie信息。 要不试试把cookie存在map里,提交数据的使用用for-each把cookie全部附加上,这样应该就不用管你咋登陆的了吧? 学习学习 感谢分享 多谢分享,还是node整wasm方案。若解说下其ckey 8.1,更好 大佬,爱奇艺cookie配置成功,输入地址解析后闪退,不知何故?能否解决?nodejs和ffmpeg都已成功安装。谢谢。 我去,这会不会被企鹅起诉啊 把芒果和B站的也一起发了吧!! 不知道企厂看到了 表情怎么样!:@ 稀罕这种PY纯干货,谢谢大佬分享。 学习学习 感谢分享 学习了,感谢分享 腾讯视频会经常更新,也不知道更新是否与这相关。目前这个可以试试 厉害,感谢分享 很强大 谢谢分享先学习学习 学习了有机会实践