2024-09-25 19:56:03 +08:00

211 lines
8.3 KiB
Python

#coding=utf-8
#!/usr/bin/python
import sys
sys.path.append('..')
from base.spider import Spider
import re
import math
import json
import time
import hashlib
import uuid
class Spider(Spider): # 元类 默认的元类 type
def getName(self):
return "1905电影网"
def init(self,extend=""):
pass
def isVideoFormat(self,url):
pass
def manualVideoCheck(self):
pass
def homeContent(self,filter):
result = {}
cateManual = {
"电影": "n_1/o3p",
"微电影":"n_1_c_922/o3p",
"系列电影":"n_2/o3p",
"记录片":"c_927/o3p",
"晚会":"n_1_c_586/o3p",
"独家":"n_1_c_178/o3p",
"综艺":"n_1_c_1024/o3p",
"体育":"n_1_c_1053/o3p"
}
classes = []
for k in cateManual:
classes.append({
'type_name':k,
'type_id':cateManual[k]
})
result['class'] = classes
return result
def homeVideoContent(self):
result = {}
url = 'https://www.1905.com/vod/cctv6/lst/'
headers = {
'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/117.0.0.0 Safari/537.36 Edg/117.0.2045.43',
'Referer': 'https://www.1905.com/vod/list/n_1/o3p1.html',
'Accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.7'
}
rsp = self.fetch(url, headers=headers)
html = self.html(rsp.text)
aList = html.xpath("//div[@class='grid-2x']/a")
videos = []
for a in aList:
aid = a.xpath("./@href")[0] #https://www.1905.com/vod/play/85646.shtml
if '//vip.1905.com' in str(aid):
continue #跳过VIP视频
aid = self.regStr(reg=r'play/(.*?).sh', src=aid) # 85646
img = a.xpath('./img/@src')[0]
title = a.xpath('./img/@alt')[0]
videos.append({
"vod_id": aid,
"vod_name": title,
"vod_pic": img,
"vod_remarks": ''
})
result['list'] = videos
return result
def categoryContent(self,tid,pg,filter,extend):
result = {}
url = 'https://www.1905.com/vod/list/{}{}.html'.format(tid, pg)
headers = {
'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/117.0.0.0 Safari/537.36 Edg/117.0.2045.43',
'Referer': 'https://www.1905.com/vod/list/n_1/o3p1.html',
'Accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.7'
}
rsp = self.fetch(url, headers=headers)
html = self.html(rsp.text)
aList = html.xpath("//section[contains(@class,'search-list')]/div/a" if tid != u'n_2/o3p' else "//div[@class='mod']/div[1]/a")
videos = []
limit = len(aList)
for a in aList:
aid = a.xpath("./@href")[0] # https://www.1905.com/vod/play/85646.shtml
aid = self.regStr(reg=r'play/(.*?).sh', src=aid) # 85646
img = a.xpath('./img/@src')[0]
title = a.xpath('./@title')[0]
videos.append({
"vod_id": aid,
"vod_name": title,
"vod_pic": img,
"vod_remarks": ''
})
result['list'] = videos
result['page'] = pg
result['pagecount'] = 100
result['limit'] = limit
result['total'] = 100 * limit
return result
def detailContent(self,array):
aid = array[0]
url = "https://www.1905.com/api/content/?callback=&m=Vod&a=getVodSidebar&id={0}&fomat=json".format(aid)
rsp = self.fetch(url)
root = json.loads(rsp.text)
title = root['title']
pic = root['thumb']
remark = root['commendreason']
content = root['description']
actor = root['starring']
direct = root['direct']
vod = {
"vod_id": aid,
"vod_name": title,
"vod_pic": pic,
"type_name": "",
"vod_year": "",
"vod_area": "",
"vod_remarks": remark,
"vod_actor": actor,
"vod_director":direct,
"vod_content": content
}
vodItems = []
vodItems.append(title + "$" + aid)
#处理多集的电影
series = root['info']['series_data']
for ser in series:
vodItems.append(ser['title'] + "$" + ser['contentid'])
playList = []
joinStr = '#'.join(vodItems)
playList.append(joinStr)
vod['vod_play_from'] = '默认最高画质'
vod['vod_play_url'] = '$$$'.join(playList)
result = {
'list': [
vod
]
}
return result
def searchContent(self,key,quick):
result = {}
url = 'https://www.1905.com/search/index-p-type-all-q-{}.html'.format(key)
headers = {
'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/117.0.0.0 Safari/537.36 Edg/117.0.2045.43',
'Referer': 'https://www.1905.com/vod/list/n_1/o3p1.html',
'Accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.7'
}
rsp = self.fetch(url, headers=headers)
html = self.html(rsp.text)
aList = html.xpath("//div[contains(@class,'movie_box')]/div/div")
videos = []
for a in aList:
aid = a.xpath("./div/ul/li[contains(@class,'paly-tab-icon')]/a/@href")[0] #https://www.1905.com/vod/play/85646.shtml
if len(aid) == 0:
continue
aid = self.regStr(reg=r'play/(.*?).sh', src=aid) # 85646
img = a.xpath('./div/div/a/img/@src')[0]
title = a.xpath('./div/a/img/@alt')[0]
videos.append({
"vod_id": aid,
"vod_name": title,
"vod_pic": img,
"vod_remarks": ''
})
result['list'] = videos
return result
def playerContent(self,flag,id,vipFlags):
result = {}
nonce = int(round(time.time() * 1000))
expiretime = nonce + 600
uid = str(uuid.uuid4())
playerid = uid.replace("-", "")[5:20]
signature = 'cid={0}&expiretime={1}&nonce={2}&page=https%3A%2F%2Fwww.1905.com%2Fvod%2Fplay%2F{3}.shtml&playerid={4}&type=hls&uuid={5}.dde3d61a0411511d'.format(id,expiretime,nonce,id,playerid,uid)
signature = hashlib.sha1(signature.encode()).hexdigest()
url = 'https://profile.m1905.com/mvod/getVideoinfo.php?nonce={0}&expiretime={1}&cid={2}&uuid={3}&playerid={4}&page=https%3A%2F%2Fwww.1905.com%2Fvod%2Fplay%2F{5}.shtml&type=hls&signature={6}&callback='.format(nonce,expiretime,id,uid,playerid,id,signature)
headers = {
'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/117.0.0.0 Safari/537.36 Edg/117.0.2045.43',
'Referer': 'https://www.1905.com/vod/list/n_1/o3p1.html',
'Accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.7'
}
rsp = self.fetch(url,headers=headers)
jo = json.loads(rsp.text.replace("(", "").replace(")", ""))
data = jo['data']['sign']
sign = ''
qualityStr = ''
if 'uhd' in data.keys():
sign = data['uhd']['sign']
qualityStr = 'uhd'
elif 'hd' in data.keys():
sign = data['hd']['sign']
qualityStr = 'hd'
elif 'sd' in data.keys():
sign = data['sd']['sign']
qualityStr = 'sd'
host = jo['data']['quality'][qualityStr]['host']
path = jo['data']['path'][qualityStr]['path']
playUrl = host + sign + path
result["parse"] = 0
result["playUrl"] = ''
result["url"] = playUrl
result["header"] = ''
return result
config = {
"player": {},
"filter": {}
}
header = {}
def localProxy(self,param):
return [200, "video/MP2T", action, ""]