'更新可用状态'

This commit is contained in:
zhangjie
2024-04-19 20:32:09 +08:00
parent 61b745341f
commit d7c2d38e50
5 changed files with 1472 additions and 4 deletions

View File

@@ -53,6 +53,10 @@ https://cdn.jsdelivr.net/gh/bizhangjie/CatVodSpider/json/index.json
https://mirror.ghproxy.com/https://github.com/bizhangjie/CatVodSpider/blob/main/json/TVBOX盒子.txt
```
```shell
https://mirror.ghproxy.com/https://github.com/bizhangjie/CatVodSpider/blob/main/json/ok.txt
```
> 韩国熊猫tv 需科学
```shell
https://api.buxiangyao.link/tvbox/tv.txt

View File

@@ -20,6 +20,7 @@ import com.github.catvod.spider.IQIYI;
import com.github.catvod.spider.Ikanbot;
import com.github.catvod.spider.Init;
import com.github.catvod.spider.J91;
import com.github.catvod.spider.JJAiPian;
import com.github.catvod.spider.Jable;
import com.github.catvod.spider.JavDb;
import com.github.catvod.spider.JustLive;
@@ -73,7 +74,7 @@ public class MainActivity extends Activity {
private void initSpider() {
try {
Init.init(getApplicationContext());
spider = new ROU223();
spider = new JJAiPian();
spider.init(this, "");
} catch (Throwable e) {
e.printStackTrace();
@@ -99,7 +100,7 @@ public class MainActivity extends Activity {
public void categoryContent(){
try {
Logger.t("categoryContent").d(spider.categoryContent("/sanjijingdian/", "2", true, new HashMap<>()));
Logger.t("categoryContent").d(spider.categoryContent("4", "2", true, new HashMap<>()));
} catch (Throwable e) {
e.printStackTrace();
}
@@ -107,7 +108,7 @@ public class MainActivity extends Activity {
public void detailContent() {
try {
Logger.t("detailContent").d(spider.detailContent(Arrays.asList("/htm/2024/4/17/yazhouxingai/630516.html")));
Logger.t("detailContent").d(spider.detailContent(Arrays.asList("628397")));
} catch (Throwable e) {
e.printStackTrace();
}

View File

@@ -0,0 +1,124 @@
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.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
public class JJAiPian extends Spider {
private static final String siteUrl = "https://www.15h2.com";
private static final String cateUrl = siteUrl + "/type/";
private static final String detailUrl = siteUrl + "/index.php/vod/play/id/";
private static final String playUrl = siteUrl + "/playl/";
private static final String searchUrl = siteUrl + "/vod/search.html?wd=";
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(siteUrl, getHeaders()));
Integer count = 0;
for (Element element : doc.select("div.header-links.header-item a")) {
if ( count >= 0 && count <= 16){
String href = element.attr("href").replace("/type/","").replace(".html","");
String text = element.text();
classes.add(new Class(href, text));
}
count ++;
}
doc = Jsoup.parse(OkHttp.string(siteUrl, getHeaders()));
for (Element element : doc.select("div.featured-content-image a")) {
try {
String pic = element.select("img").attr("data-original");
String url = element.attr("href");
String name = element.select("img").attr("alt");
String id = url.replace("/detail/","").replace(".html","");
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 + ".html";
Document doc = Jsoup.parse(OkHttp.string(target, getHeaders()));
for (Element element : doc.select("div.featured-content-image a")) {
try {
String pic = element.select("img").attr("data-original");
String url = element.attr("href");
String name = element.select("img").attr("alt");
String id = url.replace("/detail/","").replace(".html","");
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(playUrl.concat(ids.get(0)).concat("-1-1.html"), getHeaders()));
String name = doc.select("li.active").text();
String regex = "url:\"(.*?)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";
}
Vod vod = new Vod();
vod.setVodId(ids.get(0));
vod.setVodName(name);
vod.setVodPlayFrom("99aipian");
vod.setVodPlayUrl("播放$" + url);
return Result.string(vod);
}
@Override
public String searchContent(String key, boolean quick) throws Exception {
List<Vod> list = new ArrayList<>();
Document doc = Jsoup.parse(OkHttp.string(searchUrl.concat(key), getHeaders()));
for (Element element : doc.select("div.featured-content-image a")) {
try {
String pic = element.select("img").attr("data-original");
String url = element.attr("href");
String name = element.select("img").attr("alt");
String id = url.replace("/detail/","").replace(".html","");
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();
}
}

View File

@@ -90,7 +90,16 @@
"api": "csp_HiPianZhiBo",
"searchable": 1,
"filterable": 1
}, {
},
{
"key": "JJAiPian",
"name": "\uD83D\uDD1E 久久爱片 | 视频",
"type": 3,
"api": "csp_JJAiPian",
"searchable": 1,
"filterable": 1
},
{
"key": "*博天堂",
"name": "🔞博天堂",
"type": 0,

1330
json/ok.json Normal file

File diff suppressed because it is too large Load Diff