From e5269b6ed30c45426a42caf115b95fca5cceefc7 Mon Sep 17 00:00:00 2001 From: zhangjie <768284730@qq.com> Date: Sun, 5 May 2024 22:45:28 +0800 Subject: [PATCH] =?UTF-8?q?'=E6=9B=B4=E6=96=B0=E5=8F=AF=E7=94=A8=E7=8A=B6?= =?UTF-8?q?=E6=80=81'?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../com/github/catvod/debug/MainActivity.java | 5 +- .../java/com/github/catvod/spider/AvgoTv.java | 169 ++++++++++++++++++ json/index18.json | 8 - 3 files changed, 172 insertions(+), 10 deletions(-) create mode 100644 app/src/main/java/com/github/catvod/spider/AvgoTv.java diff --git a/app/src/main/java/com/github/catvod/debug/MainActivity.java b/app/src/main/java/com/github/catvod/debug/MainActivity.java index ff4d798..b16ee7e 100644 --- a/app/src/main/java/com/github/catvod/debug/MainActivity.java +++ b/app/src/main/java/com/github/catvod/debug/MainActivity.java @@ -9,6 +9,7 @@ import android.widget.Toast; import com.github.catvod.R; import com.github.catvod.crawler.Spider; +import com.github.catvod.spider.AvgoTv; import com.github.catvod.spider.CaoLiu; import com.github.catvod.spider.Cg51; import com.github.catvod.spider.DaGongRen; @@ -102,7 +103,7 @@ public class MainActivity extends Activity { public void categoryContent(){ try { - Logger.t("categoryContent").d(spider.categoryContent("6", "2", true, new HashMap<>())); + Logger.t("categoryContent").d(spider.categoryContent("1", "1", true, new HashMap<>())); } catch (Throwable e) { e.printStackTrace(); } @@ -110,7 +111,7 @@ public class MainActivity extends Activity { public void detailContent() { try { - Logger.t("detailContent").d(spider.detailContent(Arrays.asList("母亲的新男友1 回家路上遇抢劫 母亲新交热心男友 #https://hweu3.sjzsq.com/video/m3u8/202404/15/db657fc15deb/1.jpg"))); + Logger.t("detailContent").d(spider.detailContent(Arrays.asList("282642"))); } catch (Throwable e) { e.printStackTrace(); } diff --git a/app/src/main/java/com/github/catvod/spider/AvgoTv.java b/app/src/main/java/com/github/catvod/spider/AvgoTv.java new file mode 100644 index 0000000..6efbf5a --- /dev/null +++ b/app/src/main/java/com/github/catvod/spider/AvgoTv.java @@ -0,0 +1,169 @@ +package com.github.catvod.spider; + +import com.github.catvod.bean.Class; +import com.github.catvod.bean.Result; +import com.github.catvod.bean.Vod; +import com.github.catvod.crawler.Spider; +import com.github.catvod.net.OkHttp; +import com.github.catvod.utils.Util; + +import org.jsoup.Jsoup; +import org.jsoup.nodes.Document; +import org.jsoup.nodes.Element; +import org.jsoup.select.Elements; + +import java.net.URLEncoder; +import java.util.ArrayList; +import java.util.HashMap; +import java.util.List; +import java.util.regex.Matcher; +import java.util.regex.Pattern; + +public class AvgoTv extends Spider { + + private static final String siteUrl = "https://www.avgo.tv"; + private static final String picUrl = "https://vres.a357899.cn"; + private static final String cateUrl = siteUrl + "/more?type=0&searchMethods=isRecommend&searchType=0&keyword=1&page=1"; + private static final String detailUrl = siteUrl + "/detail/"; + private static final String searchUrl = siteUrl + "/more?type=0&searchMethods=isRecommend&searchType=0&keyword="; + private static final String playUrl = siteUrl + "/video-player?vid="; + + private HashMap getHeaders() { + HashMap headers = new HashMap<>(); + headers.put("User-Agent", Util.CHROME); + return headers; + } + + @Override + public String homeContent(boolean filter) throws Exception { + List list = new ArrayList<>(); + List classes = new ArrayList<>(); + String[] typeIdList = {"1", "2", "3", "4", "6"}; + String[] typeNameList = {"电影", "连续剧", "动漫", "综艺", "短剧"}; + for (int i = 0; i < typeNameList.length; i++) { + classes.add(new Class(typeIdList[i], typeNameList[i])); + } + Document doc = Jsoup.parse(OkHttp.string(siteUrl, getHeaders())); + for (Element element : doc.select("div.module-item")) { + try { + String pic = element.select("img").attr("data-original"); + String url = element.select("a").attr("href"); + String name = element.select("img").attr("title"); + if (!pic.startsWith("http")) { + pic = picUrl + pic; + } + String id = url.split("/")[2]; + list.add(new Vod(id, name, pic)); + } catch (Exception e) { + + } + } + return Result.string(classes, list); + } + + @Override + public String categoryContent(String tid, String pg, boolean filter, HashMap extend) throws Exception { + List list = new ArrayList<>(); + String target = searchUrl + tid + "&page=" + pg; + Document doc = Jsoup.parse(OkHttp.string(target, getHeaders())); + for (Element element : doc.select("div.avTypeList a")) { + try { +// String pic = element.select("img").attr("src"); + String pic = ""; + String url = element.attr("href"); + String name = element.attr("rel"); + if (!pic.startsWith("http")) { + pic = picUrl + pic; + } + String id = url.split("=")[1]; + list.add(new Vod(id, name, pic)); + } catch (Exception e) { + + } + } + Integer total = (Integer.parseInt(pg) + 1) * 20; + return Result.string(Integer.parseInt(pg), Integer.parseInt(pg) + 1, 20, total, list); + } + + @Override + public String detailContent(List ids) throws Exception { + Document doc = Jsoup.parse(OkHttp.string(detailUrl.concat(ids.get(0)), getHeaders())); + String name = doc.select("div.detail-title strong").text(); + String pic = doc.select(".detail-pic img").attr("data-original"); + String year = doc.select("a.detail-tags-item").get(0).text(); + String desc = doc.select("div.detail-desc p").text(); + + // 播放源 + Elements tabs = doc.select("a.source-item span"); + Elements list = doc.select("div.episode-list"); + String PlayFrom = ""; + String PlayUrl = ""; + for (int i = 0; i < tabs.size(); i++) { + String tabName = tabs.get(i).text(); + if (!"".equals(PlayFrom)) { + PlayFrom = PlayFrom + "$$$" + tabName; + } else { + PlayFrom = PlayFrom + tabName; + } + Elements li = list.get(i).select("a"); + String liUrl = ""; + for (int i1 = 0; i1 < li.size(); i1++) { + if (!"".equals(liUrl)) { + liUrl = liUrl + "#" + li.get(i1).text() + "$" + li.get(i1).attr("href").replace("/play/", ""); + } else { + liUrl = liUrl + li.get(i1).text() + "$" + li.get(i1).attr("href").replace("/play/", ""); + } + } + if (!"".equals(PlayUrl)) { + PlayUrl = PlayUrl + "$$$" + liUrl; + } else { + PlayUrl = PlayUrl + liUrl; + } + } + + Vod vod = new Vod(); + vod.setVodId(ids.get(0)); + vod.setVodPic(picUrl + pic); + vod.setVodYear(year); + vod.setVodName(name); + vod.setVodContent(desc); + vod.setVodPlayFrom(PlayFrom); + vod.setVodPlayUrl(PlayUrl); + return Result.string(vod); + } + + @Override + public String searchContent(String key, boolean quick) throws Exception { + List list = new ArrayList<>(); + Document doc = Jsoup.parse(OkHttp.string(searchUrl.concat(URLEncoder.encode(key)).concat(".html"), getHeaders())); + for (Element element : doc.select("a.search-result-item")) { + try { + String pic = element.select("img").attr("data-original"); + String url = element.attr("href"); + String name = element.select("img").attr("title"); + if (!pic.startsWith("http")) { + pic = picUrl + pic; + } + String id = url.split("/")[2]; + list.add(new Vod(id, name, pic)); + } catch (Exception e) { + } + } + return Result.string(list); + } + + @Override + public String playerContent(String flag, String id, List vipFlags) throws Exception { + Document doc = Jsoup.parse(OkHttp.string(playUrl.concat(id), getHeaders())); + String regex = "src: \"(.*?)m3u8\","; + + Pattern pattern = Pattern.compile(regex); + Matcher matcher = pattern.matcher(doc.html()); + String url = ""; + if (matcher.find()) { + url = matcher.group(1); + url = url.replace("\\/", "/") + "m3u8"; + } + return Result.get().url(url).header(getHeaders()).string(); + } +} diff --git a/json/index18.json b/json/index18.json index bf672e6..0c8e381 100644 --- a/json/index18.json +++ b/json/index18.json @@ -75,14 +75,6 @@ "searchable": 1, "filterable": 1 }, - { - "key": "RouVideo", - "name": "\uD83D\uDD1E 肉视频 | 科学", - "type": 3, - "api": "csp_RouVideo", - "searchable": 1, - "filterable": 1 - }, { "key": "Jable", "name": "\uD83D\uDD1E Jable | 科学",