diff --git a/app/src/main/java/com/github/catvod/spider/YHDM.java b/app/src/main/java/com/github/catvod/spider/YHDM.java new file mode 100644 index 00000000..97ec2216 --- /dev/null +++ b/app/src/main/java/com/github/catvod/spider/YHDM.java @@ -0,0 +1,171 @@ +package com.github.catvod.spider; + +import android.content.Context; +import android.net.Uri; + +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.Crypto; +import com.github.catvod.utils.Util; + +import org.json.JSONObject; +import org.jsoup.Jsoup; +import org.jsoup.nodes.Document; +import org.jsoup.nodes.Element; +import org.jsoup.select.Elements; + +import java.text.SimpleDateFormat; +import java.util.ArrayList; +import java.util.Arrays; +import java.util.Date; +import java.util.HashMap; +import java.util.List; +import java.util.Locale; +import java.util.Map; + +/** + * @author Qile + * @date 2024-10-06 + */ +public class YHDM extends Spider { + + private static String siteUrl = "https://www.857fans.com"; + private final Map configCache = new HashMap<>(); + + private Map getHeader() { + Map header = new HashMap<>(); + header.put("User-Agent", Util.CHROME); + return header; + } + + @Override + public void init(Context context, String extend) throws Exception { + if (!extend.isEmpty()) siteUrl = extend; + } + + @Override + public String homeContent(boolean filter) throws Exception { + List classes = new ArrayList<>(); + List typeIds = Arrays.asList("guochandongman", "ribendongman", "dongmandianying", "omeidongman"); + List typeNames = Arrays.asList("国产动漫", "日本动漫", "动漫电影", "欧美动漫"); + for (int i = 0; i < typeIds.size(); i++) + classes.add(new Class(typeIds.get(i), typeNames.get(i))); + + Document doc = Jsoup.parse(OkHttp.string(siteUrl, getHeader())); + List list = new ArrayList<>(); + for (Element li : doc.select(".stui-vodlist.clearfix .myui-vodlist__box")) { + String vid = li.select("a").attr("href"); + String name = li.select("a").attr("title"); + String pic = li.select("a").attr("data-original"); + if (!pic.startsWith("http")) pic = siteUrl + pic; + String remark = li.select(".pic-text.text-right").text(); + String year = li.select(".tag").text(); + list.add(new Vod(vid, name, pic, remark, year)); + } + return Result.string(classes, list); + } + + @Override + public String categoryContent(String tid, String pg, boolean filter, HashMap extend) throws Exception { + String cateUrl = siteUrl + String.format("/type/%s-%s.html", tid, pg); + Document doc = Jsoup.parse(OkHttp.string(cateUrl, getHeader())); + List list = new ArrayList<>(); + for (Element li : doc.select(".myui-vodlist__box")) { + String vid = li.select("a").attr("href"); + String name = li.select("a").attr("title"); + String pic = li.select("a").attr("data-original"); + if (!pic.startsWith("http")) pic = siteUrl + pic; + String remark = li.select(".pic-text.text-right").text(); + String year = li.select(".tag").text(); + list.add(new Vod(vid, name, pic, remark, year)); + } + return Result.string(list); + } + + @Override + public String detailContent(List ids) throws Exception { + String detailUrl = siteUrl + ids.get(0); + Document doc = Jsoup.parse(OkHttp.string(detailUrl, getHeader())); + Elements sources = doc.select(".myui-content__list.sort-list"); + Elements circuits = doc.select("a[href^=#playlist]"); + + StringBuilder vod_play_url = new StringBuilder(); + StringBuilder vod_play_from = new StringBuilder(); + for (int i = 0; i < circuits.size(); i++) { + String spanText = circuits.get(i).text(); + vod_play_from.append(spanText).append("$$$"); + Elements aElementArray = sources.get(i).select("a"); + for (int j = 0; j < aElementArray.size(); j++) { + Element a = aElementArray.get(j); + String href = a.attr("href"); + String text = a.text(); + vod_play_url.append(text).append("$").append(href); + boolean notLastEpisode = j < aElementArray.size() - 1; + vod_play_url.append(notLastEpisode ? "#" : "$$$"); + } + } + String text = doc.select(".myui-content__detail").text(); + String classifyName = Util.Matcher(text, "类型:(.*?)分类"); + String area = Util.Matcher(text, "地区:(.*?)年份"); + String year = Util.Matcher(text, "年份:(.*?)更新"); + String remark = Util.Matcher(text, "更新:(.*?)简介"); + String brief = doc.select(".col-pd.text-collapse .data").text(); + + Vod vod = new Vod(); + vod.setVodId(ids.get(0)); + vod.setVodArea(area); + vod.setVodYear(year); + vod.setVodRemarks(remark); + vod.setVodContent(brief); + vod.setTypeName(classifyName); + vod.setVodPlayFrom(vod_play_from.toString()); + vod.setVodPlayUrl(vod_play_url.toString()); + return Result.string(vod); + } + + @Override + public String searchContent(String key, boolean quick) throws Exception { + String searchUrl = siteUrl + "/search/" + Uri.encode(key) + "-------------.html"; + Document doc = Jsoup.parse(OkHttp.string(searchUrl, getHeader())); + List list = new ArrayList<>(); + for (Element li : doc.select("li.clearfix")) { + String vid = li.select("a").attr("href"); + String name = li.select("a").attr("title"); + String pic = li.select("a").attr("data-original"); + if (!pic.startsWith("http")) pic = siteUrl + pic; + String remark = li.select(".pic-text.text-right").text(); + String year = li.select(".tag").text(); + list.add(new Vod(vid, name, pic, remark, year)); + } + return Result.string(list); + } + + @Override + public String playerContent(String flag, String id, List vipFlags) throws Exception { + SimpleDateFormat dateFormat = new SimpleDateFormat("yyyyMMdd", Locale.getDefault()); + String todayDate = dateFormat.format(new Date()); + String ConfigUrl = siteUrl + "/static/js/playerconfig.js?t=" + todayDate; + if (!configCache.containsKey(ConfigUrl)) { + String ConfigContent = OkHttp.string(ConfigUrl, getHeader()); + String ConfigObject = Util.Matcher(ConfigContent, "player_list=(.*?),MacPlayerConfig"); + configCache.put(ConfigUrl, ConfigObject); + } + String content = OkHttp.string(siteUrl + id, getHeader()); + String json = Util.Matcher(content, "player_aaaa=(.*?)"); + JSONObject player = new JSONObject(json); + String aaaaUrl = player.getString("url"); + String from = player.getString("from"); + String parseUrl = new JSONObject(configCache.get(ConfigUrl)).getJSONObject(from).getString("parse"); + String parseUrls = parseUrl + aaaaUrl; + String content1 = OkHttp.string(parseUrls, getHeader()); + String playUrl = Util.Matcher(content1, "getVideoInfo\\(\"(.*?)\""); + String key = "57A891D97E332A9D"; + String iv = Util.Matcher(content1, "bt_token = \"(.*?)\""); + String realUrl = Crypto.CBC(playUrl, key, iv); + if (realUrl == null) return Result.get().url(siteUrl + id).parse().string(); + return Result.get().url(realUrl).string(); + } +} \ No newline at end of file diff --git a/app/src/main/java/com/github/catvod/utils/Util.java b/app/src/main/java/com/github/catvod/utils/Util.java index 889314a4..81b52b34 100644 --- a/app/src/main/java/com/github/catvod/utils/Util.java +++ b/app/src/main/java/com/github/catvod/utils/Util.java @@ -218,4 +218,9 @@ public class Util { return ""; } } + + public static String Matcher(String content, String pattern) { + Matcher matcher = Pattern.compile(pattern).matcher(content); + return matcher.find() ? matcher.group(1) : ""; + } } diff --git a/jar/custom_spider.jar b/jar/custom_spider.jar index f6c6dd76..51018269 100644 Binary files a/jar/custom_spider.jar and b/jar/custom_spider.jar differ diff --git a/jar/custom_spider.jar.md5 b/jar/custom_spider.jar.md5 index e5d23d5f..afa430f6 100644 --- a/jar/custom_spider.jar.md5 +++ b/jar/custom_spider.jar.md5 @@ -1 +1 @@ -673f167382cae9e4fad7bb6283f650e2 +2553b85b2f281ce4a4cbbc8d105cc7fd