diff --git a/app/src/main/java/com/github/catvod/spider/Doll.java b/app/src/main/java/com/github/catvod/spider/Doll.java new file mode 100644 index 00000000..f5c187b4 --- /dev/null +++ b/app/src/main/java/com/github/catvod/spider/Doll.java @@ -0,0 +1,36 @@ +package com.github.catvod.spider; + +import com.github.catvod.crawler.Spider; + +import java.util.HashMap; +import java.util.List; + +public class Doll extends Spider { + + private final String url = "https://hongkongdollvideo.com/"; + + @Override + public String homeContent(boolean filter) throws Exception { + return super.homeContent(filter); + } + + @Override + public String categoryContent(String tid, String pg, boolean filter, HashMap extend) throws Exception { + return super.categoryContent(tid, pg, filter, extend); + } + + @Override + public String detailContent(List ids) throws Exception { + return super.detailContent(ids); + } + + @Override + public String searchContent(String key, boolean quick) throws Exception { + return super.searchContent(key, quick); + } + + @Override + public String playerContent(String flag, String id, List vipFlags) throws Exception { + return super.playerContent(flag, id, vipFlags); + } +} diff --git a/app/src/main/java/com/github/catvod/spider/Eighteen.java b/app/src/main/java/com/github/catvod/spider/Eighteen.java index 700d3750..2143095c 100644 --- a/app/src/main/java/com/github/catvod/spider/Eighteen.java +++ b/app/src/main/java/com/github/catvod/spider/Eighteen.java @@ -32,7 +32,7 @@ public class Eighteen extends Spider { String typeName = a.text(); String typeId = a.attr("href").replace(url, ""); if (!typeId.contains("random/all/")) continue; - if (typeName.contains("18H漫畫")) break; + if (typeName.contains("18H")) break; classes.add(new Class(typeId, typeName)); } for (Element div : doc.select("div.post")) { diff --git a/app/src/main/java/com/github/catvod/spider/Miss.java b/app/src/main/java/com/github/catvod/spider/Miss.java new file mode 100644 index 00000000..05dae498 --- /dev/null +++ b/app/src/main/java/com/github/catvod/spider/Miss.java @@ -0,0 +1,103 @@ +package com.github.catvod.spider; + +import android.text.TextUtils; + +import com.github.catvod.bean.Class; +import com.github.catvod.bean.Filter; +import com.github.catvod.bean.Result; +import com.github.catvod.bean.Vod; +import com.github.catvod.crawler.Spider; +import com.github.catvod.net.OkHttpUtil; + +import org.jsoup.Jsoup; +import org.jsoup.nodes.Document; +import org.jsoup.nodes.Element; + +import java.util.ArrayList; +import java.util.Arrays; +import java.util.HashMap; +import java.util.LinkedHashMap; +import java.util.List; + +public class Miss extends Spider { + + private final String site = "https://missav.com/"; + + @Override + public String homeContent(boolean filter) throws Exception { + List list = new ArrayList<>(); + List classes = new ArrayList<>(); + LinkedHashMap> filters = new LinkedHashMap<>(); + List typeIds = Arrays.asList("chinese-subtitle", "new", "release", "uncensored-leak", "siro", "luxu", "gana", "maan", "scute", "ara", "uncensored-leak", "fc2", "heyzo", "tokyohot", "1pondo", "caribbeancom", "caribbeancompr", "10musume", "pacopacomama", "gachinco", "xxxav", "marriedslash", "naughty4610", "naughty0930", "madou", "twav"); + Document doc = Jsoup.parse(OkHttpUtil.string(site)); + for (Element a : doc.select("nav").select("a")) { + String typeName = a.text(); + String typeId = a.attr("href").replace(site, ""); + if (!typeIds.contains(typeId)) continue; + classes.add(new Class(typeId, typeName)); + filters.put(typeId, List.of(new Filter("filters", "過濾", Arrays.asList(new Filter.Value("全部", ""), new Filter.Value("單人作品", "individual"), new Filter.Value("中文字幕", "chinese-subtitle"))))); + } + for (Element div : doc.select("div.thumbnail")) { + String id = div.select("a.text-secondary").attr("href").replace(site, ""); + String name = div.select("a.text-secondary").text(); + String pic = div.select("img").attr("data-src"); + if (pic.isEmpty()) pic = div.select("img").attr("src"); + String remark = div.select("span").text(); + list.add(new Vod(id, name, pic, remark)); + } + return Result.string(classes, list, filters); + } + + @Override + public String categoryContent(String tid, String pg, boolean filter, HashMap extend) throws Exception { + List list = new ArrayList<>(); + String url = site + tid; + String filters = extend.get("filters"); + if (TextUtils.isEmpty(filters)) url += "?page=" + pg; + else url += "?filters=" + extend.get("filters") + "&page=" + pg; + Document doc = Jsoup.parse(OkHttpUtil.string(url)); + for (Element div : doc.select("div.thumbnail")) { + String id = div.select("a.text-secondary").attr("href").replace(site, ""); + String name = div.select("a.text-secondary").text(); + String pic = div.select("img").attr("data-src"); + if (pic.isEmpty()) pic = div.select("img").attr("src"); + String remark = div.select("span").text(); + list.add(new Vod(id, name, pic, remark)); + } + return Result.string(list); + } + + @Override + public String detailContent(List ids) throws Exception { + Document doc = Jsoup.parse(OkHttpUtil.string(site + ids.get(0))); + String name = doc.select("meta[property=og:title]").attr("content"); + String pic = doc.select("meta[property=og:image]").attr("content"); + Vod vod = new Vod(); + vod.setVodId(ids.get(0)); + vod.setVodPic(pic); + vod.setVodName(name); + vod.setVodPlayFrom("MissAV"); + vod.setVodPlayUrl("播放$" + ids.get(0)); + return Result.string(vod); + } + + @Override + public String searchContent(String key, boolean quick) throws Exception { + List list = new ArrayList<>(); + Document doc = Jsoup.parse(OkHttpUtil.string(site + "search/" + key)); + for (Element div : doc.select("div.thumbnail")) { + String id = div.select("a.text-secondary").attr("href").replace(site, ""); + String name = div.select("a.text-secondary").text(); + String pic = div.select("img").attr("data-src"); + if (pic.isEmpty()) pic = div.select("img").attr("src"); + String remark = div.select("span").text(); + list.add(new Vod(id, name, pic, remark)); + } + return Result.string(list); + } + + @Override + public String playerContent(String flag, String id, List vipFlags) throws Exception { + return Result.get().parse().url(site + id).string(); + } +} diff --git a/jar/custom_spider.jar b/jar/custom_spider.jar index 887cfe2b..4281262b 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 061a77f6..886540ae 100644 --- a/jar/custom_spider.jar.md5 +++ b/jar/custom_spider.jar.md5 @@ -1 +1 @@ -f491cfb7367a7dcc57bbc7a484614a24 +0555de475e5d35fba55d58abb5c4568e