update CAT

This commit is contained in:
qist 2024-04-12 14:29:25 +08:00
parent bdda250293
commit 3aa58c947b
8 changed files with 450 additions and 394 deletions

File diff suppressed because one or more lines are too long

View File

@ -1 +1 @@
bc8f18599a94263d004576e5506e8ca3 576fae86365190bf5b44b5a5de56fde1

349
cat/dist/index.js vendored

File diff suppressed because one or more lines are too long

View File

@ -1 +1 @@
d420a0bc83dc0fa1e549de94127ad58d 4393866d86b1531e38ec0699d5a57747

View File

@ -18,6 +18,22 @@ class Doll extends Spider {
this.siteUrl = "https://hongkongdollvideo.com" this.siteUrl = "https://hongkongdollvideo.com"
} }
async spiderInit(inReq = null) {
if (inReq !== null) {
this.jsBase = await js2Proxy(inReq, "img", {});
} else {
this.jsBase = await js2Proxy(true, this.siteType, this.siteKey, 'img/', {});
}
}
async init(cfg) {
await super.init(cfg);
await this.spiderInit(null)
}
async getHtml(url = this.siteUrl, proxy = false, headers = this.getHeader()) {
return super.getHtml(url, true, headers);
}
getName() { getName() {
return "🔞┃玩偶姐姐┃🔞" return "🔞┃玩偶姐姐┃🔞"
@ -44,7 +60,13 @@ class Doll extends Spider {
let videoInfoElements = $($(vodElement).find("[class=\"video-info\"]")).find("a") let videoInfoElements = $($(vodElement).find("[class=\"video-info\"]")).find("a")
vodShort.vod_name = videoInfoElements[0].attribs["title"] vodShort.vod_name = videoInfoElements[0].attribs["title"]
vodShort.vod_remarks = $(videoInfoElements[1]).text() vodShort.vod_remarks = $(videoInfoElements[1]).text()
vodShort.vod_pic = $(vodElement).find("img")[0].attribs["data-src"] let pic = $(vodElement).find("img")[0].attribs["data-src"]
if (this.catOpenStatus) {
vodShort.vod_pic = this.jsBase + Utils.base64Encode(pic)
} else {
vodShort.vod_pic = pic
}
vod_list.push(vodShort) vod_list.push(vodShort)
} }
return vod_list return vod_list
@ -55,10 +77,16 @@ class Doll extends Spider {
let vodElement = $("[class=\"container-fluid\"]") let vodElement = $("[class=\"container-fluid\"]")
vodDetail.vod_name = $($(vodElement).find("[class=\"page-title\"]")[0]).text() vodDetail.vod_name = $($(vodElement).find("[class=\"page-title\"]")[0]).text()
vodDetail.vod_remarks = $(vodElement).find("[class=\"tag my-1 text-center\"]")[0].attribs["href"].replaceAll("/", "") vodDetail.vod_remarks = $(vodElement).find("[class=\"tag my-1 text-center\"]")[0].attribs["href"].replaceAll("/", "")
vodDetail.vod_pic = $(vodElement).find("video")[0].attribs["poster"] let pic = $(vodElement).find("video")[0].attribs["poster"]
if (this.catOpenStatus) {
vodDetail.vod_pic = this.jsBase + Utils.base64Encode(pic)
} else {
vodDetail.vod_pic = pic
}
let html = $.html() let html = $.html()
let voteTag = Utils.getStrByRegex(/var voteTag="(.*?)";/g, html) let voteTag = Utils.getStrByRegex(/var voteTag="(.*?)";/g, html)
let videoInfo = JSON.parse(Utils.getStrByRegex(/<script type="application\/ld\+json">(.*?)<\/script>/g, html)) // let videoInfoStr = Utils.getStrByRegex(/<script type="application\/ld\+json">(.*?)<\/script>/g, html)
// let videoInfo = JSON.parse(videoInfoStr)
// //
// try { // try {
// let play_url_1 = await this.fetch(videoInfo["contentUrl"], null, this.getHeader()) // let play_url_1 = await this.fetch(videoInfo["contentUrl"], null, this.getHeader())
@ -81,9 +109,7 @@ class Doll extends Spider {
} }
async setClasses() { async setClasses() {
let html = await this.fetch(this.siteUrl, null, this.getHeader()) let $ = await this.getHtml(this.siteUrl)
if (html !== null) {
let $ = load(html)
let navElements = $("[class=\"list-unstyled topnav-menu d-flex d-lg-block align-items-center justify-content-center flex-fill topnav-menu-left m-0\"]").find("li") let navElements = $("[class=\"list-unstyled topnav-menu d-flex d-lg-block align-items-center justify-content-center flex-fill topnav-menu-left m-0\"]").find("li")
let index = 1 let index = 1
let class_id = index.toString() let class_id = index.toString()
@ -126,18 +152,14 @@ class Doll extends Spider {
} }
this.classes.push(type_dic) this.classes.push(type_dic)
} }
}
}
} }
}
async setHomeVod() { async setHomeVod() {
let html = await this.fetch(this.siteUrl, null, this.getHeader()) let $ = await this.getHtml(this.siteUrl)
if (html != null) {
let $ = load(html)
this.homeVodList = await this.parseVodShortListFromDoc($) this.homeVodList = await this.parseVodShortListFromDoc($)
} }
}
async setCategory(tid, pg, filter, extend) { async setCategory(tid, pg, filter, extend) {
if (extend["1"] !== undefined) { if (extend["1"] !== undefined) {
@ -153,21 +175,15 @@ class Doll extends Spider {
cateUrl = this.siteUrl cateUrl = this.siteUrl
} }
this.limit = 36 this.limit = 36
let html = await this.fetch(cateUrl, null, this.getHeader()) let $ = await this.getHtml(cateUrl)
if (html != null) {
let $ = load(html)
this.vodList = await this.parseVodShortListFromDoc($) this.vodList = await this.parseVodShortListFromDoc($)
} }
}
async setDetail(id) { async setDetail(id) {
let html = await this.fetch(id, null, this.getHeader()) let $ = await this.getHtml(id)
if (html != null) {
let $ = load(html)
let key = Utils.getStrByRegex(/video\/(\w+).html/, id) let key = Utils.getStrByRegex(/video\/(\w+).html/, id)
this.vodDetail = await this.parseVodDetailFromDoc($, key) this.vodDetail = await this.parseVodDetailFromDoc($, key)
} }
}
async setPlay(flag, id, flags) { async setPlay(flag, id, flags) {
this.playUrl = id this.playUrl = id
@ -176,11 +192,12 @@ class Doll extends Spider {
async setSearch(wd, quick) { async setSearch(wd, quick) {
let searchUrl = this.siteUrl + "search/" + encodeURIComponent(wd) let searchUrl = this.siteUrl + "search/" + encodeURIComponent(wd)
let html = await this.fetch(searchUrl, null, this.getHeader()) let $ = await this.getHtml(searchUrl)
if (html !== null) {
let $ = load(html)
this.vodList = await this.parseVodShortListFromDoc($) this.vodList = await this.parseVodShortListFromDoc($)
} }
async proxy(segments, headers) {
return super.proxy(segments, headers);
} }
} }

View File

@ -19,6 +19,20 @@ class JableTVSpider extends Spider {
} }
async spiderInit(inReq = null) {
if (inReq !== null) {
this.jsBase = await js2Proxy(inReq, "img", {});
} else {
this.jsBase = await js2Proxy(true, this.siteType, this.siteKey, 'img/', {});
}
}
async init(cfg) {
await super.init(cfg);
await this.spiderInit(null)
}
getAppName() { getAppName() {
return "Jable" return "Jable"
} }
@ -26,6 +40,7 @@ class JableTVSpider extends Spider {
getName() { getName() {
return "🔞┃Jable┃🔞" return "🔞┃Jable┃🔞"
} }
getJSName() { getJSName() {
return "jable" return "jable"
} }
@ -43,6 +58,10 @@ class JableTVSpider extends Spider {
return header return header
} }
async getHtml(url = this.siteUrl, proxy = false, headers = this.getHeader()) {
return super.getHtml(url, true, headers);
}
async setClasses() { async setClasses() {
let $ = await this.getHtml(this.siteUrl) let $ = await this.getHtml(this.siteUrl)
let navElements = $("[class=\"title-box\"]") let navElements = $("[class=\"title-box\"]")
@ -148,20 +167,28 @@ class JableTVSpider extends Spider {
let vodElements = $("div.video-img-box") let vodElements = $("div.video-img-box")
for (const element of vodElements) { for (const element of vodElements) {
let vodShort = new VodShort() let vodShort = new VodShort()
vodShort.vod_pic = $(element).find("img").attr("data-src"); let vod_pic = $(element).find("img").attr("data-src")
if (vod_pic !== undefined) {
if (this.catOpenStatus) {
vodShort.vod_pic = this.jsBase + Utils.base64Encode(vod_pic)
} else {
vodShort.vod_pic = vod_pic
}
let url = $(element).find("a").attr("href"); let url = $(element).find("a").attr("href");
vodShort.vod_id = url.split("/")[4]; vodShort.vod_id = url.split("/")[4];
vodShort.vod_name = url.split("/")[4]; vodShort.vod_name = url.split("/")[4];
let remarks_list = $($(element).find("[class=\"sub-title\"]")).text().split("\n") let remarks_list = $($(element).find("[class=\"sub-title\"]")).text().split("\n")
if (remarks_list.length > 1){ if (remarks_list.length > 1) {
vodShort.vod_remarks = remarks_list[1].replaceAll(" ", "").replaceAll("\t", "") vodShort.vod_remarks = remarks_list[1].replaceAll(" ", "").replaceAll("\t", "")
}else{ } else {
vodShort.vod_remarks = "精选" vodShort.vod_remarks = "精选"
} }
if (!_.isEmpty(vodShort.vod_pic) && vodShort.vod_remarks !== "[限時優惠]只需1元即可無限下載"){ if (!_.isEmpty(vodShort.vod_pic) && vodShort.vod_remarks !== "[限時優惠]只需1元即可無限下載") {
vod_list.push(vodShort); vod_list.push(vodShort);
} }
} }
}
return vod_list return vod_list
} }
@ -169,9 +196,14 @@ class JableTVSpider extends Spider {
let vodDetail = new VodDetail(); let vodDetail = new VodDetail();
let leftElement = $("[class=\"header-left\"]") let leftElement = $("[class=\"header-left\"]")
vodDetail.vod_name = $($(leftElement).find("h4")).text(); vodDetail.vod_name = $($(leftElement).find("h4")).text();
vodDetail.vod_pic = Utils.getStrByRegex(/<video poster="(.*?)" id=/, $.html()) let vod_pic = Utils.getStrByRegex(/<video poster="(.*?)" id=/, $.html())
if (this.catOpenStatus) {
vodDetail.vod_pic = this.jsBase + Utils.base64Encode(vod_pic)
} else {
vodDetail.vod_pic = vod_pic
}
vodDetail.vod_year = $($("[class=\"inactive-color\"]")).text() vodDetail.vod_year = $($("[class=\"inactive-color\"]")).text()
let episodeName = $($("[class=\"header-right d-none d-md-block\"] > h6")).text().replaceAll("\n", "").replaceAll("●","") let episodeName = $($("[class=\"header-right d-none d-md-block\"] > h6")).text().replaceAll("\n", "").replaceAll("●", "")
let vodItems = [] let vodItems = []
let episodeUrl = Utils.getStrByRegex(/var hlsUrl = '(.*?)';/, $.html()) let episodeUrl = Utils.getStrByRegex(/var hlsUrl = '(.*?)';/, $.html())
vodItems.push(episodeName + "$" + episodeUrl) vodItems.push(episodeName + "$" + episodeUrl)
@ -271,4 +303,5 @@ export function __jsEvalReturn() {
proxy: proxy proxy: proxy
}; };
} }
export {spider} export {spider}

View File

@ -73,7 +73,7 @@ class Result {
"format": this.format, "format": this.format,
"subs": this.subs, "subs": this.subs,
"danmaku": this.danmaku, "danmaku": this.danmaku,
"extra":this.extra, "extra": this.extra,
"jx": this.jx "jx": this.jx
}) })
} else { } else {
@ -83,14 +83,16 @@ class Result {
"header": this.header, "header": this.header,
"format": this.format, "format": this.format,
"subs": this.subs, "subs": this.subs,
"extra":this.extra, "extra": this.extra,
"jx": this.jx "jx": this.jx
}) })
} }
} }
playTxt(url){
playTxt(url) {
return url return url
} }
errorCategory(error_message) { errorCategory(error_message) {
let vodShort = new VodShort() let vodShort = new VodShort()
vodShort.vod_name = "错误:打开无效" vodShort.vod_name = "错误:打开无效"
@ -245,8 +247,8 @@ class Spider {
return {"type_name": type_name, "type_id": type_id} return {"type_name": type_name, "type_id": type_id}
} }
async getHtml(url = this.siteUrl, headers = this.getHeader()) { async getHtml(url = this.siteUrl, proxy = false, headers = this.getHeader()) {
let html = await this.fetch(url, null, headers) let html = await this.fetch(url, null, headers, false, false, 0, proxy)
if (!_.isEmpty(html)) { if (!_.isEmpty(html)) {
return load(html) return load(html)
} else { } else {
@ -278,14 +280,14 @@ class Spider {
return {"User-Agent": Utils.CHROME, "Referer": this.siteUrl + "/"}; return {"User-Agent": Utils.CHROME, "Referer": this.siteUrl + "/"};
} }
async getResponse(reqUrl, params, headers, redirect_url, return_cookie, buffer, response) { async getResponse(reqUrl, params, headers, redirect_url, return_cookie, buffer, response,proxy) {
{ {
if (response.headers["location"] !== undefined) { if (response.headers["location"] !== undefined) {
if (redirect_url) { if (redirect_url) {
await this.jadeLog.debug(`返回重定向连接:${response.headers["location"]}`) await this.jadeLog.debug(`返回重定向连接:${response.headers["location"]}`)
return response.headers["location"] return response.headers["location"]
} else { } else {
return this.fetch(response.headers["location"], params, headers, redirect_url, return_cookie, buffer) return this.fetch(response.headers["location"], params, headers, redirect_url, return_cookie, buffer,proxy)
} }
} else if (response.content.length > 0) { } else if (response.content.length > 0) {
this.reconnectTimes = 0 this.reconnectTimes = 0
@ -299,13 +301,13 @@ class Spider {
return response.content return response.content
} else { } else {
await this.jadeLog.error(`请求失败,请求url为:${reqUrl},回复内容为:${JSON.stringify(response)}`) await this.jadeLog.error(`请求失败,请求url为:${reqUrl},回复内容为:${JSON.stringify(response)}`)
return await this.reconnnect(reqUrl, params, headers, redirect_url, return_cookie, buffer) return await this.reconnnect(reqUrl, params, headers, redirect_url, return_cookie, buffer,proxy)
} }
} }
} }
async fetch(reqUrl, params, headers, redirect_url = false, return_cookie = false, buffer = 0) { async fetch(reqUrl, params, headers, redirect_url = false, return_cookie = false, buffer = 0, proxy = false) {
let data = Utils.objectToStr(params) let data = Utils.objectToStr(params)
let url = reqUrl let url = reqUrl
if (!_.isEmpty(data)) { if (!_.isEmpty(data)) {
@ -315,13 +317,13 @@ class Spider {
let response; let response;
if (redirect_url) { if (redirect_url) {
response = await req(uri.toString(), { response = await req(uri.toString(), {
method: "get", headers: headers, buffer: buffer, data: null, redirect: 2 method: "get", headers: headers, buffer: buffer, data: null, redirect: 2, proxy: proxy
}) })
} else { } else {
response = await req(uri.toString(), {method: "get", headers: headers, buffer: buffer, data: null}); response = await req(uri.toString(), {method: "get", headers: headers, buffer: buffer, data: null,proxy:proxy});
} }
if (response.code === 200 || response.code === 302 || response.code === 301 || return_cookie) { if (response.code === 200 || response.code === 302 || response.code === 301 || return_cookie) {
return await this.getResponse(reqUrl, params, headers, redirect_url, return_cookie, buffer, response) return await this.getResponse(reqUrl, params, headers, redirect_url, return_cookie, buffer, response,proxy)
} else { } else {
await this.jadeLog.error(`请求失败,失败原因为:状态码出错,请求url为:${uri},回复内容为:${JSON.stringify(response)}`) await this.jadeLog.error(`请求失败,失败原因为:状态码出错,请求url为:${uri},回复内容为:${JSON.stringify(response)}`)
return await this.reconnnect(reqUrl, params, headers, redirect_url, return_cookie, buffer) return await this.reconnnect(reqUrl, params, headers, redirect_url, return_cookie, buffer)
@ -693,10 +695,12 @@ class Spider {
async getImg(url, headers) { async getImg(url, headers) {
let resp; let resp;
let use_proxy = false // 使用代理不需要加headers
if (_.isEmpty(headers)) { if (_.isEmpty(headers)) {
headers = {Referer: url, 'User-Agent': Utils.CHROME} headers = {Referer: url, 'User-Agent': Utils.CHROME}
use_proxy = true
} }
resp = await req(url, {buffer: 2, headers: headers}); resp = await req(url, {buffer: 2, headers: headers,proxy:use_proxy});
try { try {
Utils.base64Decode(resp.content) Utils.base64Decode(resp.content)
await this.jadeLog.error(`图片代理获取失败,重连失败`, true) await this.jadeLog.error(`图片代理获取失败,重连失败`, true)

View File

@ -1,4 +1,4 @@
import {__jsEvalReturn} from './bilibili.js'; import {__jsEvalReturn} from './jable.js';
import * as Utils from "../lib/utils.js"; import * as Utils from "../lib/utils.js";