# 1. 拿到contId
# 2. 拿到videoStatus返回的json. -> srcURL
# 3. srcURL里面的内容进行修整
# 4. 下载视频
import requests
# 拉取视频的网址
url = "https://www.pearvideo.com/video_1721605"
contId = url.split("_")[1] #拿到需要替换的后面数字序列
#网址前加f是为了使用如下的格式化数据填充形式
videoStatusUrl = f"https://www.pearvideo.com/videoStatus.jsp?contId={contId}"
headers = {
"User-Agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_4) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/88.0.4324.192 Safari/537.36",
# 防盗链: 溯源, 当前本次请求的上一级是谁,会自动识别从那个页面过来的,直接访问视频不给数据
"Referer": url
}
resp = requests.get(videoStatusUrl, headers=headers)
#将结果转化为字典形式,便于通过键值形式获取数据
dic = resp.json()
#获取视频地址
srcUrl = dic['videoInfo']['videos']['srcUrl']
#获取系统时间
systemTime = dic['systemTime']
#替换数据,获得真实的视频数据
srcUrl = srcUrl.replace(systemTime, f"cont-{contId}")
# 下载视频,写视频要用字节形式,跟图片一样
with open("ab.mp4", mode="wb") as f:
f.write(requests.get(srcUrl).content)
7_防盗链的处理
于 2022-03-09 08:28:50 首次发布