'更新可用状态'

This commit is contained in:
zhangjie 2024-03-13 11:16:33 +08:00
parent 42296902c7
commit c6652158eb
5 changed files with 139 additions and 4 deletions
app/src/main/java/com/github/catvod
jar
json

@ -20,6 +20,7 @@ import com.github.catvod.spider.JustLive;
import com.github.catvod.spider.QxiTv;
import com.github.catvod.spider.W55Movie;
import com.github.catvod.spider.Wogg;
import com.github.catvod.spider.XVideos;
import com.github.catvod.spider.Zhaozy;
import com.orhanobut.logger.AndroidLogAdapter;
import com.orhanobut.logger.Logger;
@ -59,7 +60,7 @@ public class MainActivity extends Activity {
private void initSpider() {
try {
Init.init(getApplicationContext());
spider = new W55Movie();
spider = new XVideos();
spider.init(this, "");
} catch (Throwable e) {
e.printStackTrace();
@ -84,7 +85,7 @@ public class MainActivity extends Activity {
public void categoryContent() {
try {
Logger.t("categoryContent").d(spider.categoryContent("/vodshow/124", "2", true, new HashMap<>()));
Logger.t("categoryContent").d(spider.categoryContent("", "2", true, new HashMap<>()));
} catch (Throwable e) {
e.printStackTrace();
}
@ -92,7 +93,7 @@ public class MainActivity extends Activity {
public void detailContent() {
try {
Logger.t("detailContent").d(spider.detailContent(Arrays.asList("454873.html")));
Logger.t("detailContent").d(spider.detailContent(Arrays.asList("/video79810059/_")));
} catch (Throwable e) {
e.printStackTrace();
}

@ -0,0 +1,126 @@
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 java.net.URLEncoder;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Locale;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
public class XVideos extends Spider {
private static final String siteUrl = "https://cn.xvideos2.uk";
private static final String cateUrl = siteUrl + "/best/";
private static final String detailUrl = siteUrl;
private static final String searchUrl = siteUrl + "/?k=";
private HashMap<String, String> getHeaders() {
HashMap<String, String> headers = new HashMap<>();
headers.put("User-Agent", Util.CHROME);
return headers;
}
@Override
public String homeContent(boolean filter) throws Exception {
List<Vod> list = new ArrayList<>();
List<Class> classes = new ArrayList<>();
Document doc = Jsoup.parse(OkHttp.string(cateUrl,getHeaders()));
for (Element element : doc.select("div#date-links-pagination").select("li")) {
try {
String typeId = element.select("a").attr("href").split("/")[2];
String typeName = element.select("a").text();
classes.add(new Class(typeId, typeName));
}catch (Exception e){
}
}
doc = Jsoup.parse(OkHttp.string(siteUrl, getHeaders()));
for (Element element : doc.select("div.thumb-block")) {
try {
String pic = element.select("img").attr("src");
String id = element.select("a").attr("href");
String name = element.select("p.title").select("a").attr("title");
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<String, String> extend) throws Exception {
List<Vod> list = new ArrayList<>();
String target = cateUrl + tid + "/" + pg;
Document doc = Jsoup.parse(OkHttp.string(target, getHeaders()));
for (Element element : doc.select("div.thumb-block")) {
try {
String pic = element.select("img").attr("src");
String id = element.select("a").attr("href");
String name = element.select("p.title").select("a").attr("title");
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<String> ids) throws Exception {
Document doc = Jsoup.parse(OkHttp.string(detailUrl.concat(ids.get(0)).concat("/"), getHeaders()));
String name = doc.select("meta[property=og:title]").attr("content");
String pic = doc.select("meta[property=og:image]").attr("content");
Pattern pattern = Pattern.compile("\"contentUrl\\\": \\\"(.*?)\\\",");
Matcher matcher = pattern.matcher(doc.html());
String PlayUrl = "";
// 提取匹配到的内容
if (matcher.find()) {
PlayUrl = matcher.group(1);
}
Vod vod = new Vod();
vod.setVodId(ids.get(0));
vod.setVodPic(pic);
vod.setVodName(name);
vod.setVodPlayFrom("XVideos");
vod.setVodPlayUrl("播放$" + PlayUrl);
return Result.string(vod);
}
@Override
public String searchContent(String key, boolean quick) throws Exception {
List<Vod> list = new ArrayList<>();
String target = searchUrl + URLEncoder.encode(key) + "&p=1";
Document doc = Jsoup.parse(OkHttp.string(target, getHeaders()));
for (Element element : doc.select("div.thumb-block")) {
try {
String pic = element.select("img").attr("src");
String id = element.select("a").attr("href");
String name = element.select("p.title").select("a").attr("title");
list.add(new Vod(id, name, pic));
}catch (Exception e){
}
}
return Result.string(list);
}
@Override
public String playerContent(String flag, String id, List<String> vipFlags) throws Exception {
return Result.get().url(id).header(getHeaders()).string();
}
}

Binary file not shown.

@ -1 +1 @@
3ec28751a5a9a4b999cdb063e063e456
1e2a8f46eac7e31b1ab65bcec3a13ec8

@ -70,6 +70,14 @@
"searchable": 1,
"filterable": 1
},
{
"key": "XVideos",
"name": "XVideos",
"type": 3,
"api": "csp_XVideos",
"searchable": 1,
"filterable": 1
},
{
"key": "push_agent",
"name": "推送",