diff --git a/app/src/main/java/com/github/catvod/demo/MainActivity.java b/app/src/main/java/com/github/catvod/demo/MainActivity.java index 2a3de8c1..61a98f45 100644 --- a/app/src/main/java/com/github/catvod/demo/MainActivity.java +++ b/app/src/main/java/com/github/catvod/demo/MainActivity.java @@ -12,6 +12,7 @@ public class MainActivity extends Activity { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); new Thread(() -> { + }).start(); } } \ No newline at end of file diff --git a/app/src/main/java/com/github/catvod/spider/Eighteen.java b/app/src/main/java/com/github/catvod/spider/Eighteen.java new file mode 100644 index 00000000..a533f68f --- /dev/null +++ b/app/src/main/java/com/github/catvod/spider/Eighteen.java @@ -0,0 +1,116 @@ +package com.github.catvod.spider; + +import android.os.SystemClock; +import android.webkit.WebView; +import android.webkit.WebViewClient; + +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.OkHttpUtil; +import com.github.catvod.utils.Misc; + +import org.jsoup.Jsoup; +import org.jsoup.nodes.Document; +import org.jsoup.nodes.Element; + +import java.util.ArrayList; +import java.util.HashMap; +import java.util.List; + +public class Eighteen extends Spider { + + private final String url = "https://maa1812.com/zh/"; + + @Override + public String homeContent(boolean filter) throws Exception { + List classes = new ArrayList<>(); + List list = new ArrayList<>(); + Document doc = Jsoup.parse(OkHttpUtil.string(url)); + for (Element a : doc.select("ul.animenu__nav > li > a")) { + String typeName = a.text(); + String typeId = a.attr("href").replace(url, ""); + if (!typeId.contains("random/all/")) continue; + if (typeName.contains("18H漫畫")) break; + classes.add(new Class(typeId, typeName)); + } + for (Element div : doc.select("div.post")) { + String id = div.select("a").attr("href").replace(url, ""); + String name = div.select("h3").text(); + String pic = div.select("a > img").attr("src"); + String remark = div.select("div.meta").text(); + list.add(new Vod(id, name, pic, remark)); + } + return Result.string(classes, list); + } + + @Override + public String categoryContent(String tid, String pg, boolean filter, HashMap extend) throws Exception { + List list = new ArrayList<>(); + tid = tid.replace("random", "list"); + tid = tid.replace("index", pg); + Document doc = Jsoup.parse(OkHttpUtil.string(url + tid)); + for (Element div : doc.select("div.post")) { + String id = div.select("a").attr("href").replace(url, ""); + String name = div.select("h3").text(); + String pic = div.select("a > img").attr("src"); + String remark = div.select("div.meta").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(url + ids.get(0))); + Element wrap = doc.select("div.video-wrap").get(0); + String name = wrap.select("div.archive-title > h1").text(); + String pic = wrap.select("div.player-wrap > img").attr("src"); + Vod vod = new Vod(); + vod.setVodId(ids.get(0)); + vod.setVodPic(pic); + vod.setVodName(name); + vod.setVodPlayFrom("18AV"); + vod.setVodPlayUrl("播放$" + ids.get(0)); + return Result.string(vod); + } + + @Override + public String searchContent(String key, boolean quick) throws Exception { + HashMap params = new HashMap<>(); + params.put("search_keyword", key); + params.put("search_type", "fc"); + params.put("op", "search"); + String res = OkHttpUtil.post(url + "searchform_search/all/index.html", params); + List list = new ArrayList<>(); + for (Element div : Jsoup.parse(res).select("div.post")) { + String id = div.select("a").attr("href").replace(url, ""); + String name = div.select("h3").text(); + String pic = div.select("a > img").attr("src"); + String remark = div.select("div.meta").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 { + HashMap result = new HashMap<>(); + Misc.loadWebView(url + id, getClient(result)); + while (result.isEmpty()) SystemClock.sleep(250); + return Result.get().url(result.get("url")).string(); + } + + private WebViewClient getClient(HashMap result) { + return new WebViewClient() { + @Override + public void onLoadResource(WebView view, String url) { + if (url.endsWith(".m3u8")) { + result.put("url", url); + view.destroy(); + } + } + }; + } +} diff --git a/jar/custom_spider.jar b/jar/custom_spider.jar index 8f4b3bd3..7ef6d1ac 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 d0420d05..42529df8 100644 --- a/jar/custom_spider.jar.md5 +++ b/jar/custom_spider.jar.md5 @@ -1 +1 @@ -df0dabb326716ff4fcf608d067a8dd6f +15eff96043ef1e975fb86b88cdc8809b