update CAT
This commit is contained in:
parent
bdda250293
commit
3aa58c947b
File diff suppressed because one or more lines are too long
@ -1 +1 @@
|
|||||||
bc8f18599a94263d004576e5506e8ca3
|
576fae86365190bf5b44b5a5de56fde1
|
||||||
349
cat/dist/index.js
vendored
349
cat/dist/index.js
vendored
File diff suppressed because one or more lines are too long
2
cat/dist/index.js.md5
vendored
2
cat/dist/index.js.md5
vendored
@ -1 +1 @@
|
|||||||
d420a0bc83dc0fa1e549de94127ad58d
|
4393866d86b1531e38ec0699d5a57747
|
||||||
@ -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);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@ -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,7 +167,13 @@ 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];
|
||||||
@ -162,6 +187,8 @@ class JableTVSpider extends Spider {
|
|||||||
vod_list.push(vodShort);
|
vod_list.push(vodShort);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
}
|
||||||
return vod_list
|
return vod_list
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -169,7 +196,12 @@ 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 = []
|
||||||
@ -271,4 +303,5 @@ export function __jsEvalReturn() {
|
|||||||
proxy: proxy
|
proxy: proxy
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
export {spider}
|
export {spider}
|
||||||
@ -88,9 +88,11 @@ class Result {
|
|||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
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)
|
||||||
|
|||||||
@ -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";
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user