Merge pull request #45 from qlql765/main

88看球源
This commit is contained in:
FongMi 2023-11-06 09:01:34 +08:00 committed by GitHub
commit 7982da9cdf
1 changed files with 122 additions and 0 deletions

View File

@ -0,0 +1,122 @@
package com.github.catvod.spider;
import android.content.Context;
import android.text.TextUtils;
import com.github.catvod.crawler.Spider;
import org.json.JSONArray;
import org.json.JSONObject;
import org.jsoup.Jsoup;
import org.jsoup.nodes.Document;
import org.jsoup.nodes.Element;
import com.github.catvod.net.OkHttp;
import com.github.catvod.utils.Utils;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import com.github.catvod.bean.Result;
import com.github.catvod.bean.Vod;
import com.github.catvod.bean.Class;
/**
* @author Qile
*/
public class Kanqiu extends Spider {
private static String siteUrl = "http://www.88kanqiu.one";
private Map<String, String> getHeader() {
Map<String, String> header = new HashMap<>();
header.put("User-Agent", Utils.CHROME);
return header;
}
@Override
public void init(Context context, String extend) throws Exception {
super.init(context, extend);
if (!extend.isEmpty()) {
siteUrl = extend;
}
}
@Override
public String homeContent(boolean filter) throws Exception {
List<Class> classes = new ArrayList<>();
List<String> typeIds = Arrays.asList("", "1", "8", "29");
List<String> typeNames = Arrays.asList("全部直播", "篮球直播", "足球直播", "其他直播");
for (int i = 0; i < typeIds.size(); i++)
classes.add(new Class(typeIds.get(i), typeNames.get(i)));
String f = "{\"1\": [{\"key\": \"cateId\", \"name\": \"类型\", \"value\": [{\"n\": \"NBA\", \"v\": \"1\"}, {\"n\": \"CBA\", \"v\": \"2\"}, {\"n\": \"篮球综合\", \"v\": \"4\"}, {\"n\": \"纬来体育\", \"v\": \"21\"}]}],\"8\": [{\"key\": \"cateId\", \"name\": \"类型\", \"value\": [{\"n\": \"英超\", \"v\": \"8\"}, {\"n\": \"西甲\", \"v\": \"9\"}, {\"n\": \"意甲\", \"v\": \"10\"}, {\"n\": \"欧冠\", \"v\": \"12\"}, {\"n\": \"欧联\", \"v\": \"13\"}, {\"n\": \"德甲\", \"v\": \"14\"}, {\"n\": \"法甲\", \"v\": \"15\"}, {\"n\": \"欧国联\", \"v\": \"16\"}, {\"n\": \"足总杯\", \"v\": \"27\"}, {\"n\": \"国王杯\", \"v\": \"33\"}, {\"n\": \"中超\", \"v\": \"7\"}, {\"n\": \"亚冠\", \"v\": \"11\"}, {\"n\": \"足球综合\", \"v\": \"23\"}, {\"n\": \"欧协联\", \"v\": \"28\"}, {\"n\": \"美职联\", \"v\": \"26\"}]}], \"29\": [{\"key\": \"cateId\", \"name\": \"类型\", \"value\": [{\"n\": \"网球\", \"v\": \"29\"}, {\"n\": \"斯洛克\", \"v\": \"30\"}, {\"n\": \"MLB\", \"v\": \"38\"}, {\"n\": \"UFC\", \"v\": \"32\"}, {\"n\": \"NFL\", \"v\": \"25\"}, {\"n\": \"CCTV5\", \"v\": \"18\"}]}]}";
JSONObject filterConfig = new JSONObject(f);
return Result.string(classes, filterConfig);
}
@Override
public String categoryContent(String tid, String pg, boolean filter, HashMap<String, String> extend)
throws Exception {
HashMap<String, String> ext = new HashMap<>();
if (extend != null && extend.size() > 0) {
ext.putAll(extend);
}
String cateId = ext.get("cateId") == null ? tid : ext.get("cateId");
String cateUrl;
if (cateId == null || cateId.isEmpty()) {
cateUrl = siteUrl + String.format("%s", tid);
} else {
cateUrl = siteUrl + String.format("/match/%s/live", cateId);
}
Document doc = Jsoup.parse(OkHttp.string(cateUrl, getHeader()));
List<Vod> list = new ArrayList<>();
int Size = 0;
for (Element li : doc.select(".list-group-item")) {
Size = doc.select(".list-group-item").size();
String vid = siteUrl + li.select(".btn.btn-primary").attr("href");
String name = li.select(".row.d-none").text();
if (name.isEmpty()) name = li.text();
String pic = li.select(".col-xs-1").eq(0).select("img").attr("src");
if (pic.isEmpty()) pic = "https://qlql.link/b/日期.jpg";
if (!pic.startsWith("http")) pic = siteUrl + pic;
String remark = li.select(".btn.btn-primary").text();
list.add(new Vod(vid, name, pic, remark));
}
Result result = Result.get().page(1, 1, 0, Size).vod(list);
return result.string();
}
@Override
public String detailContent(List<String> ids) throws Exception {
Document doc = Jsoup.parse(OkHttp.string(ids.get(0), getHeader()));
Document doc1 = Jsoup.parse(OkHttp.string(ids.get(0) + "-url", getHeader()));
JSONArray jsonArray = new JSONArray(doc1.text());
List<String> vodItems = new ArrayList<>();
for (int i = 0; i < jsonArray.length(); i++) {
JSONObject dataObject = jsonArray.getJSONObject(i);
String text = dataObject.optString("name");
String href = dataObject.optString("url");
vodItems.add(text + "$" + href);
}
String vod_play_from = "Qile";
String vod_play_url = TextUtils.join("#", vodItems);
String title = doc.select(".game-info-container").text();
String pic = doc.select(".col-md-4.text-center img").attr("src");
Vod vod = new Vod();
vod.setVodId(ids.get(0));
vod.setVodPic(pic);
vod.setVodName(title);
vod.setVodPlayFrom(vod_play_from.toString());
vod.setVodPlayUrl(vod_play_url.toString());
return Result.string(vod);
}
@Override
public String playerContent(String flag, String id, List<String> vipFlags) throws Exception {
return Result.get().url(id).parse().header(getHeader()).string();
}
}