# -*- coding: utf-8 -*- # @Author : Doubebly # @Time : 2025/3/23 21:55 import base64 import sys import time import json import requests import re from datetime import datetime sys.path.append('..') from base.spider import Spider from bs4 import BeautifulSoup class Spider(Spider): def getName(self): return "Litv" def init(self, extend): self.extend = extend try: self.extendDict = json.loads(extend) except: self.extendDict = {} proxy = self.extendDict.get('proxy', None) if proxy is None: self.is_proxy = False else: self.proxy = proxy self.is_proxy = True pass def getDependence(self): return [] def isVideoFormat(self, url): pass def manualVideoCheck(self): pass def liveContent(self, url): cookies = { '_ga': 'GA1.1.782627561.1745936696', '_oredge_rl': 'u1ORyxILkguVwZ3LWQNJTpqceYPzrL/Cgugwu74xDwA=', 'dailyMessageShown515': 'shown', '_ga_F2ET4TBC70': 'GS2.1.s1747232930$o3$g1$t1747233259$j0$l0$h0', } headers = { '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.7', 'accept-language': 'zh-CN,zh;q=0.9', 'cache-control': 'max-age=0', 'priority': 'u=0, i', 'sec-ch-ua': '"Chromium";v="136", "Google Chrome";v="136", "Not.A/Brand";v="99"', 'sec-ch-ua-mobile': '?0', 'sec-ch-ua-platform': '"Windows"', 'sec-fetch-dest': 'document', 'sec-fetch-mode': 'navigate', 'sec-fetch-site': 'none', 'sec-fetch-user': '?1', 'upgrade-insecure-requests': '1', 'user-agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/136.0.0.0 Safari/537.36', # 'cookie': '_ga=GA1.1.782627561.1745936696; _oredge_rl=u1ORyxILkguVwZ3LWQNJTpqceYPzrL/Cgugwu74xDwA=; dailyMessageShown515=shown; _ga_F2ET4TBC70=GS2.1.s1747232930$o3$g1$t1747233259$j0$l0$h0', } response = requests.get('https://www.515001.tv/', cookies=cookies, headers=headers) #print(response.text) #自己添加,表示输出响应的内容 html = response.text soup = BeautifulSoup(html, 'html.parser') matches = [] for a in soup.find_all('a', class_='clearfix'): # 提取链接 link = a.get('href', '') link = f"video://{link}" # 提取赛事名称和时间 event_time_p = a.find('p', class_='eventtime_wuy') if event_time_p: em = event_time_p.find('em') event_name = em.get_text(strip=True) if em else '' i_tag = event_time_p.find('i') time = i_tag.get_text(strip=True) if i_tag else '' else: event_name = '' time = '' # 提取主队名称 home_div = a.find('div', class_=lambda c: c and 'zhudui' in c) home_team = home_div.find('p').get_text(strip=True) if home_div else '' # 提取客队名称 away_div = a.find('div', class_='kedui') away_team = away_div.find('p').get_text(strip=True) if away_div else '' if event_name and home_team and away_team and time and link: match_str = f"[{event_name}]{home_team} VS {away_team}{time},{link}" matches.append(match_str) m3u_content = ['#EXTM3U'] for match in matches: title = match.split(",")[0] ch_url = match.split(",")[1] extinf = f'#EXTINF:-1 tvg-name="{title}" group-title="515001",{title}' m3u_content.extend([extinf, ch_url]) return '\n'.join(m3u_content) def homeContent(self, filter): return {} def homeVideoContent(self): return {} def categoryContent(self, cid, page, filter, ext): return {} def detailContent(self, did): return {} def searchContent(self, key, quick, page='1'): return {} def searchContentPage(self, keywords, quick, page): return {} def playerContent(self, flag, pid, vipFlags): return {} def localProxy(self, params): if params['type'] == "m3u8": return self.proxyM3u8(params) if params['type'] == "ts": return self.get_ts(params) return [302, "text/plain", None, {'Location': 'https://sf1-cdn-tos.huoshanstatic.com/obj/media-fe/xgplayer_doc_video/mp4/xgplayer-demo-720p.mp4'}] def proxyM3u8(self, params): pid = params['pid'] info = pid.split(',') a = info[0] b = info[1] c = info[2] timestamp = int(time.time() / 4 - 355017625) t = timestamp * 4 m3u8_text = f'#EXTM3U\n#EXT-X-VERSION:3\n#EXT-X-TARGETDURATION:4\n#EXT-X-MEDIA-SEQUENCE:{timestamp}\n' for i in range(10): url = f'https://ntd-tgc.cdn.hinet.net/live/pool/{a}/litv-pc/{a}-avc1_6000000={b}-mp4a_134000_zho={c}-begin={t}0000000-dur=40000000-seq={timestamp}.ts' if self.is_proxy: url = f'http://127.0.0.1:9978/proxy?do=py&type=ts&url={self.b64encode(url)}' m3u8_text += f'#EXTINF:4,\n{url}\n' timestamp += 1 t += 4 return [200, "application/vnd.apple.mpegurl", m3u8_text] def get_ts(self, params): url = self.b64decode(params['url']) headers = {'User-Agent': 'Mozilla/5.0'} response = requests.get(url, headers=headers, stream=True, proxies=self.proxy) return [206, "application/octet-stream", response.content] def destroy(self): return '正在Destroy' def b64encode(self, data): return base64.b64encode(data.encode('utf-8')).decode('utf-8') def b64decode(self, data): return base64.b64decode(data.encode('utf-8')).decode('utf-8') if __name__ == '__main__': pass