“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)
html = resp.content.decode(“utf-8”)
print(html)
videoId = re.compile(“videoId: ‘(.*?)’”)
showid = re.compile(“showid: ‘(.*?)’”)
currentEncodeVid = re.compile(“currentEncodeVid: ‘(.*?)’”)
videoId = videoId.findall(html, re.S | re.M | re.I)
current_showid = showid.findall(html, re.S | re.M | re.I)
vid = currentEncodeVid.findall(html, re.S | re.M | re.I)
return {“current_showid”: current_showid[0], “videoId”: videoId[0], “vid”: vid[0]}
def get_emb(self, videoId):
emb = base64.b64encode((“%swww.youku.com/” % videoId).encode(‘utf-8’)).decode(‘utf-8’)
return emb
这个函数用来获取元素的第一个值
def takeOne(self, elem):
return float(elem[0])
def m3u8_url(self, t, params_data, sign):
url = “https://acs.youku.com/h5/mtop.youku.play.ups.appinfo.get/1.1/”
params = {
“jsv”: “2.5.8”,
“appKey”: “24679788”,
“t”: t,
“sign”: sign,
“api”: “mtop.youku.play.ups.appinfo.get”,
“v”: “1.1”,
“timeout”: “20000”,
“YKPid”: “20160317PLF000211”,
“YKLoginRequest”: “true”,
“AntiFlood”: “true”,
“AntiCreep”: “true”,
“type”: “jsonp”,
“dataType”: “jsonp”,
“callback”: “mtopjsonp1”,
“data”: params_data,
}
headers = {
“Accept”: “/”,
“Accept-Encoding”: “gzip, deflate, br”,
“Accept-Language”: “zh-CN,zh;q=0.9”,
“Connection”: “keep-alive”,
“Cookie”: self.cookie,
“Host”: “acs.youku.com”,
“Referer”: “https://v.youku.com/v_show/id_XNTA1MTYwMzU0OA==.html?spm=a2h0c.8166622.PhoneSokuUgc_3.dscreenshot”,
“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)
result =resp.text
print(result)
data = json.loads(result[12:-1])
print(data)
ret = data[“ret”]
video_lists = []
if ret == [“SUCCESS::调用成功”]:
stream = data[“data”][“data”][“stream”]
title = data[“data”][“data”][“video”][“title”]
print(“解析成功:”)
for video in stream:
m3u8_url = video[“m3u8_url”]
width = video[“width”]
height = video[“height”]
size = video[“size”]
size = ‘{:.1f}’.format(float(size) / 1048576)
video_lists.append([size, width, height, title, m3u8_url])
print(f">>> {title} 分辨率:{width}x{height} 视频大小:{size}M \tm3u8播放地址:{m3u8_url}")
video_lists.sort(key=self.takeOne)
for video_list in video_lists:
print(f">>> {title} 分辨率:{video_list[1]}x{video_list[2]} 视频大小:{video_list[0]}M \tm3u8播放地址:{video_list[4]}")
self.play(video_lists[-1][4]) # 选择播放列表最后一个视频(经过sort排序后,最后一个即为清晰度最高的一个)
elif ret == [“FAIL_SYS_ILLEGAL_ACCESS::非法请求”]:
print(“请求参数错误”)
elif ret == [“FAIL_SYS_TOKEN_EXOIRED::令牌过期”]:
print(“Cookie过期”)
else:
print(ret[0])
def play(self, x):
text = ‘ffplay -protocol_whitelist “file,http,https,rtp,udp,tcp,tls” -loglevel quiet -i “%s”’ % x
subprocess.call(text, shell=True)
def start(self):
while True:
try:
t = str(int(time.time() * 1000))
user_info = self.utid()
userid = user_info[“utid”]
url = input(“\n\n请将优酷视频播放链接粘贴到这:\n”)
url = self.redirect(url)
page_info = self.page_parser(url)
emb = self.get_emb(page_info[“videoId”])
params_data = r’‘’{“steal_params”:“{“ccode”:“0502”,“client_ip”:“192.168.1.1”,“utid”:”%s",“client_ts”:%s,“version”:“2.1.69”,“ckey”:“DIl58SLFxFNndSV1GFNnMQVYkx1PP5tKe1siZu/86PR1u/Wh1Ptd+WOZsHHWxysSfAOhNJpdVWsdVJNsfJ8Sxd8WKVvNfAS8aS8fAOzYARzPyPc3JvtnPHjTdKfESTdnuTW6ZPvk2pNDh4uFzotgdMEFkzQ5wZVXl2Pf1/Y6hLK0OnCNxBj3+nb0v72gZ6b0td+WOZsHHWxysSo/0y9D2K42SaB8Y/+aD2K42SaB8Y/+ahU+WOZsHcrxysooUeND”}“,“biz_params”:”{“vid”:“%s”,“play_ability”:16782592,“current_showid”:“%s”,“preferClarity”:99,“extag”:“EXT-X-PRIVINF”,“master_m3u8”:1,“media_type”:“standard,subtitle”,“app_ver”:“2.1.69”,“h265”:1}“,“ad_params”:”{“vs”:“1.0”,“pver”:“2.1.69”,“sver”:“2.0”,“site”:1,“aw”:“w”,“fu”:0,“d”:“0”,“bt”:“pc”,“os”:“win”,“osv”:“10”,“dq”:“auto”,“atm”:“”,“partnerid”:“null”,“wintype”:“interior”,“isvert”:0,“vip”:1,“emb”:“%s”,“p”:1,“rst”:“mp4”,“needbf”:2,“avs”:“1.0”}"}‘’'% (userid, t[:10], page_info[“vid”], page_info[“current_showid”], emb)
sign = self.youku_sign(t, params_data, user_info[“token”])
self.m3u8_url(t, params_data, sign)
except Exception as e:
print(‘error:’,e , “或可能cookie设置错误”)
break
if name == ‘main’:
print(“=”*35 +‘>> 欢迎使用优酷视频m3u8地址解析工具 <<’+“=”*35)
cookie = input(“\n使用前,请设置优酷的cookie:\n”)
print(“\n这是一个循环:可以不停的解析…”)
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数Python工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Python开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Python开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新
如果你觉得这些内容对你有帮助,可以添加V获取:vip1024c (备注Python)
.png)
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Python开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新
如果你觉得这些内容对你有帮助,可以添加V获取:vip1024c (备注Python)
[外链图片转存中…(img-QU5Upn79-1712712195592)]