This commit is contained in:
GH Action - Upstream Sync 2023-08-23 12:29:51 +00:00
commit 4650058343
3 changed files with 34 additions and 28 deletions

View File

@ -17,7 +17,12 @@ import com.github.catvod.BuildConfig;
import com.github.catvod.bean.Result; import com.github.catvod.bean.Result;
import com.github.catvod.bean.Sub; import com.github.catvod.bean.Sub;
import com.github.catvod.bean.Vod; import com.github.catvod.bean.Vod;
import com.github.catvod.bean.ali.*; import com.github.catvod.bean.ali.Code;
import com.github.catvod.bean.ali.Data;
import com.github.catvod.bean.ali.Drive;
import com.github.catvod.bean.ali.Item;
import com.github.catvod.bean.ali.OAuth;
import com.github.catvod.bean.ali.User;
import com.github.catvod.crawler.SpiderDebug; import com.github.catvod.crawler.SpiderDebug;
import com.github.catvod.net.OkHttp; import com.github.catvod.net.OkHttp;
import com.github.catvod.net.OkResult; import com.github.catvod.net.OkResult;
@ -412,7 +417,7 @@ public class API {
private String getPreviewContent(String[] ids) { private String getPreviewContent(String[] ids) {
try { try {
JSONObject playInfo = getVideoPreviewPlayInfo(ids[0]); JSONObject playInfo = getVideoPreviewPlayInfo(ids[0]);
String url = getPreviewUrl(playInfo); List<String> url = getPreviewUrl(playInfo);
List<Sub> subs = getSubs(ids); List<Sub> subs = getSubs(ids);
subs.addAll(getSubs(playInfo)); subs.addAll(getSubs(playInfo));
return Result.get().url(url).m3u8().subs(subs).header(getHeader()).string(); return Result.get().url(url).m3u8().subs(subs).header(getHeader()).string();
@ -422,19 +427,17 @@ public class API {
} }
} }
private String getPreviewUrl(JSONObject playInfo) throws Exception { private List<String> getPreviewUrl(JSONObject playInfo) throws Exception {
if (!playInfo.has("live_transcoding_task_list")) return ""; if (!playInfo.has("live_transcoding_task_list")) return Collections.emptyList();
JSONArray taskList = playInfo.getJSONArray("live_transcoding_task_list"); JSONArray taskList = playInfo.getJSONArray("live_transcoding_task_list");
List<String> templates = Arrays.asList("UHD", "QHD", "FHD", "HD", "SD", "LD"); List<String> url = new ArrayList<>();
for (String template : templates) { for (int i = taskList.length() - 1; i >= 0; i--) {
for (int i = 0; i < taskList.length(); ++i) { JSONObject task = taskList.getJSONObject(i);
JSONObject task = taskList.getJSONObject(i); if (!task.optString("status").equals("finished")) continue;
if (task.getString("template_id").equals(template)) { url.add(task.optString("template_id"));
return task.getString("url"); url.add(task.optString("url"));
}
}
} }
return taskList.getJSONObject(0).getString("url"); return url;
} }
private List<Sub> getSubs(JSONObject playInfo) throws Exception { private List<Sub> getSubs(JSONObject playInfo) throws Exception {

View File

@ -26,7 +26,7 @@ public class Result {
@SerializedName("format") @SerializedName("format")
private String format; private String format;
@SerializedName("url") @SerializedName("url")
private String url; private Object url;
@SerializedName("subs") @SerializedName("subs")
private List<Sub> subs; private List<Sub> subs;
@SerializedName("parse") @SerializedName("parse")
@ -131,6 +131,11 @@ public class Result {
return this; return this;
} }
public Result url(List<String> url) {
this.url = url;
return this;
}
public Result format(String format) { public Result format(String format) {
this.format = format; this.format = format;
return this; return this;

View File

@ -58,7 +58,6 @@ public class Bili extends Spider {
private JsonObject extend; private JsonObject extend;
private String cookie; private String cookie;
private boolean login; private boolean login;
private boolean vip;
private Map<String, String> getHeader(String cookie) { private Map<String, String> getHeader(String cookie) {
Map<String, String> headers = new HashMap<>(); Map<String, String> headers = new HashMap<>();
@ -163,22 +162,22 @@ public class Bili extends Spider {
vod.setVodContent(detail.getDesc()); vod.setVodContent(detail.getDesc());
vod.setVodRemarks(detail.getDuration() / 60 + "分鐘"); vod.setVodRemarks(detail.getDuration() / 60 + "分鐘");
Map<String, String> vod_play = new LinkedHashMap<>(); LinkedHashMap<String, String> flag = new LinkedHashMap<>();
ArrayList<String> playList = new ArrayList<>(); ArrayList<String> episode = new ArrayList<>();
for (Page page : detail.getPages()) playList.add(page.getPart() + "$" + aid + "+" + page.getCid()); for (Page page : detail.getPages()) episode.add(page.getPart() + "$" + aid + "+" + page.getCid());
vod_play.put("B站", TextUtils.join("#", playList)); flag.put("B站", TextUtils.join("#", episode));
episode = new ArrayList<>();
api = "https://api.bilibili.com/x/web-interface/archive/related?bvid=" + id; api = "https://api.bilibili.com/x/web-interface/archive/related?bvid=" + id;
JSONArray related = new JSONObject(OkHttp.string(api, getMember())).optJSONArray("data"); JSONArray array = new JSONObject(OkHttp.string(api, getMember())).optJSONArray("data");
playList = new ArrayList<>(); for (int i = 0; i < array.length(); i++) {
for (int i = 0; i < related.length(); i++) { JSONObject object = array.getJSONObject(i);
JSONObject relatedData = related.getJSONObject(i); episode.add(object.getString("title") + "$" + object.optLong("aid") + "+" + object.optLong("cid"));
playList.add(relatedData.getString("title") + "$" + relatedData.optLong("aid") + "+" + relatedData.optLong("cid"));
} }
vod_play.put("相关推荐", TextUtils.join("#", playList)); flag.put("相关推荐", TextUtils.join("#", episode));
vod.setVodPlayFrom(TextUtils.join("$$$", vod_play.keySet())); vod.setVodPlayFrom(TextUtils.join("$$$", flag.keySet()));
vod.setVodPlayUrl(TextUtils.join("$$$", vod_play.values())); vod.setVodPlayUrl(TextUtils.join("$$$", flag.values()));
return Result.string(vod); return Result.string(vod);
} }
@ -258,7 +257,6 @@ public class Bili extends Spider {
private void checkLogin() { private void checkLogin() {
String json = OkHttp.string("https://api.bilibili.com/x/web-interface/nav", getMember()); String json = OkHttp.string("https://api.bilibili.com/x/web-interface/nav", getMember());
Data data = Resp.objectFrom(json).getData(); Data data = Resp.objectFrom(json).getData();
vip = data.getVipType() > 0;
login = data.isLogin(); login = data.isLogin();
getQRCode(); getQRCode();
} }