2024-05-14 22:28:15 +08:00
import cheerio from "assets://js/lib/cheerio.min.js" ;
import "assets://js/lib/crypto-js.js" ;
import "./jsencrypt.js" ;
2024-05-26 13:39:40 +08:00
import "./node-rsa.js" ;
import "./pako.min.js" ;
2024-05-14 22:28:15 +08:00
import 模板 from "./模板.js" ;
import {
gbkTool
}
from "./gbk.js" ;
function init _test ( ) {
console . log ( "init_test_start" ) ;
console . log ( "当前版本号:" + VERSION ) ;
2024-05-26 13:39:40 +08:00
console . log ( "本地代理地址:" + getProxyUrl ( ) ) ;
2024-05-14 22:28:15 +08:00
console . log ( RKEY ) ;
console . log ( JSON . stringify ( rule ) ) ;
console . log ( "init_test_end" )
}
2024-05-26 13:39:40 +08:00
function ocr _demo _test ( ) {
let img _base64 = ` iVBORw0KGgoAAAANSUhEUgAAAIAAAAAoBAMAAADEX+97AAAAG1BMVEXz+/4thQTa7N6QwIFFkyNeokKozqDB3b93sWHFR+MEAAAACXBIWXMAAA7EAAAOxAGVKw4bAAABN0lEQVRIie2TQU+DQBCFt9vScvQpxR4xrcSjJCZ67JDGXsX+AdR4B3vpsSYm/m2HXaRLmuySepR3Gdidb/btDAjRq5dT96eCMlfBuzi1QLZUoZy2yz5sOvI+9iomaPEZ6nWnEtxqIyiM1RcAy44GNDhBXUjot/VVNweV1ah68FqWRyjKIOqAcyYF6rGcmpYnHzGt3fycNoMw0d3/THFu7hFSJ/8OXO6iTM8/KSg09obAzIHLO250LgQ0txOZSfgrV4Exdw98uGycJ0ErAeExZGhOmFHV9zHO6qVSj0MpLq7xZON56o++MjlsEgfVhbQWWME+xQX7J4V6zfi9A1Ly9rP1BvEXp+BbVJ/M77n+wfOIDVp51pZ4iBxvmj9AGrtvry6emwfKnVkW+ZRKd5ZNMvob36vXP9YPDmQki8QiCFAAAAAASUVORK5CYII= ` ;
OcrApi . api = OCR _API ;
let code = OcrApi . classification ( img _base64 ) ;
log ( "测试验证码图片的ocr识别结果为:" + code )
}
function rsa _demo _test ( ) {
let t1 = ( new Date )
. getTime ( ) ;
let pkcs1 _public = `
-- -- - BEGIN RSA PUBLIC KEY -- -- -
MEgCQQCrI0pQ / ERRpJ3Ou190XJedFq846nDYP52rOtXyDxlFK5D3p6JJu2RwsKwy
lsQ9xY0xYPpRZUZKMEeR7e9gmRNLAgMBAAE =
-- -- - END RSA PUBLIC KEY -- -- -
` .trim();
let pkcs1 _public _pem = `
MEgCQQCrI0pQ / ERRpJ3Ou190XJedFq846nDYP52rOtXyDxlFK5D3p6JJu2RwsKwy
lsQ9xY0xYPpRZUZKMEeR7e9gmRNLAgMBAAE =
` .trim();
let pkcs8 _public = `
-- -- - BEGIN PUBLIC KEY -- -- -
MFwwDQYJKoZIhvcNAQEBBQADSwAwSAJBAKsjSlD8RFGknc67X3Rcl50WrzjqcNg /
nas61fIPGUUrkPenokm7ZHCwrDKWxD3FjTFg + lFlRkowR5Ht72CZE0sCAwEAAQ ==
-- -- - END PUBLIC KEY -- -- - ` .trim();
let pkcs8 _public _pem = `
MFwwDQYJKoZIhvcNAQEBBQADSwAwSAJBAKsjSlD8RFGknc67X3Rcl50WrzjqcNg /
nas61fIPGUUrkPenokm7ZHCwrDKWxD3FjTFg + lFlRkowR5Ht72CZE0sCAwEAAQ ==
` .trim();
let pkcs1 _private = `
-- -- - BEGIN RSA PRIVATE KEY -- -- -
MIIBOAIBAAJBAKsjSlD8RFGknc67X3Rcl50WrzjqcNg / nas61fIPGUUrkPenokm7
ZHCwrDKWxD3FjTFg + lFlRkowR5Ht72CZE0sCAwEAAQI / b6OV1z65UokQaMvSeRXt
0 Yv6wiYtduQI9qpq5nzy / ytaqsbBfClNTi / HifKPKxlRouWFkc518EQI8LBxoarJ
AiEA4DaONMplV8PQNa3TKn2F + SDEvLOCjdL0kHKdN90Ti28CIQDDZnTBaHgZwZbA
hS7Bbf5yvwjWMhO6Y7l04 / Qm7R + 35 QIgPuQuqXIoUSD080mp1N5WyRW ++ atksIF +
5 lGv9e6GP / MCICnj8y / rl6Pd7tXDN6zcSeqLrfdNsREKhB3dKOCXgW9JAiAFYtFS
EJNBXVRTK42SNsZ2hJ / 9 xLwOwnH2epT8Q43s3Q ==
-- -- - END RSA PRIVATE KEY -- -- -
` .trim();
let pkcs8 _private = `
-- -- - BEGIN PRIVATE KEY -- -- -
MIIBUgIBADANBgkqhkiG9w0BAQEFAASCATwwggE4AgEAAkEAqyNKUPxEUaSdzrtf
dFyXnRavOOpw2D + dqzrV8g8ZRSuQ96eiSbtkcLCsMpbEPcWNMWD6UWVGSjBHke3v
YJkTSwIDAQABAj9vo5XXPrlSiRBoy9J5Fe3Ri / rCJi125Aj2qmrmfPL / K1qqxsF8
KU1OL8eJ8o8rGVGi5YWRznXwRAjwsHGhqskCIQDgNo40ymVXw9A1rdMqfYX5IMS8
s4KN0vSQcp033ROLbwIhAMNmdMFoeBnBlsCFLsFt / nK / CNYyE7pjuXTj9CbtH7fl
AiA + 5 C6pcihRIPTzSanU3lbJFb75q2SwgX7mUa / 17 oY / 8 wIgKePzL + uXo93u1cM3
rNxJ6out902xEQqEHd0o4JeBb0kCIAVi0VIQk0FdVFMrjZI2xnaEn / 3 EvA7CcfZ6
lPxDjezd
-- -- - END PRIVATE KEY -- -- -
` .trim();
let data = `
NodeRsa
这是node - rsa 现在修改集成在drpy里使用 ` .trim();
let encryptedWithPublic = NODERSA . encryptRSAWithPublicKey ( data , pkcs1 _public , {
outputEncoding : "base64" ,
options : {
environment : "browser" ,
encryptionScheme : "pkcs1_oaep"
}
} ) ;
console . log ( "公钥加密" ) ;
console . log ( encryptedWithPublic ) ;
let decryptedWithPrivate = NODERSA . decryptRSAWithPrivateKey ( encryptedWithPublic , pkcs1 _private , {
options : {
environment : "browser" ,
encryptionScheme : "pkcs1_oaep"
}
} ) ;
console . log ( "私钥解密" ) ;
console . log ( decryptedWithPrivate ) ;
let pkcs1 _sha256 _sign = NODERSA . sign ( "1" , pkcs1 _private , {
outputEncoding : "base64" ,
options : {
environment : "browser" ,
encryptionScheme : "pkcs1" ,
signingScheme : "pkcs1-sha256"
}
} ) ;
console . log ( "pkcs1_sha256_sign" ) ;
console . log ( pkcs1 _sha256 _sign ) ;
let pkcs1 _sha256 _sign _verify = NODERSA . verify ( "1" , "Oulx2QrgeipKYBtqEDqFb2s/+ndk2cGQxO4CkhU7iBM1vyNmmvqubpsmeoUuN3waGrYZLknSEdwBkfv0tUMpFQ==" , pkcs1 _private , {
options : {
environment : "browser" ,
encryptionScheme : "pkcs1" ,
signingScheme : "pkcs1-sha256"
}
} ) ;
console . log ( "pkcs1_sha256_sign_verify" ) ;
console . log ( pkcs1 _sha256 _sign _verify ) ;
let pkcs1 _oaep _sha256 = NODERSA . encryptRSAWithPublicKey ( data , ` -----BEGIN RSA PUBLIC KEY-----
MIIBCgKCAQEA5KOq1gRNyllLNWKQy8sGpZE3Q1ULLSmzZw + eaAhj9lvqn7IsT1du
SYn08FfoOA2qMwtz + 1 O2l1mgzNoSVCyVpVabnTG + C9XKeZXAnJHd8aYA7l7Sxhdm
kte + iymYZ0ZBPzijo8938iugtVvqi9UgDmnY3u / NlQDqiL5BGqSxSTd / Sgmy3zD8
PYzEa3wD9vehQ5fZZ45vKIq8GNVh2Z8 + IGO85FF1OsN7 + b2yGJa / FmDDNn0 + HP + m
PfI + kYBqEVpo0Ztbc3UdxgFwGC8O1n8AQyriwHnSOtIiuBH62J / 7 qyC / 3 LEAApRb
Dd9YszqzmODjQUddZKHmvc638VW + azc0EwIDAQAB
-- -- - END RSA PUBLIC KEY -- -- -
` , {
outputEncoding : "base64" ,
options : {
environment : "browser" ,
encryptionScheme : {
scheme : "pkcs1_oaep" ,
hash : "sha256"
}
}
} ) ;
console . log ( "pkcs1_oaep_sha256" ) ;
console . log ( pkcs1 _oaep _sha256 ) ;
decryptedWithPrivate = NODERSA . decryptRSAWithPrivateKey ( "kSZesAAyYh2hdsQnYMdGqb6gKAzTauBKouvBzWcc4+F8RvGd0nwO6mVkUMVilPgUuNxjEauHayHiY8gI3Py45UI3+km0rSGyHrS6dHiHgCkMejXHieglYzAB0IxX3Jkm4z/66bdB/D+GFy0oct5fGCMI1UHPjEAYOsazJDa8lBFNbjiWFeb/qiZtIx3vGM7KYPAZzyRf/zPbbQ8zy9xOmRuOl5nnIxgo0Okp3KO/RIPO4GZOSBA8f2lx1UtNwwrXAMpcNavtoqHVcjJ/9lcotXYQFrn5b299pSIRf2gVm8ZJ31SK6Z8cc14nKtvgnmsgClDzIXJ1o1RcDK+knVAySg==" , ` -----BEGIN RSA PRIVATE KEY-----
MIIEpAIBAAKCAQEA5KOq1gRNyllLNWKQy8sGpZE3Q1ULLSmzZw + eaAhj9lvqn7Is
T1duSYn08FfoOA2qMwtz + 1 O2l1mgzNoSVCyVpVabnTG + C9XKeZXAnJHd8aYA7l7S
xhdmkte + iymYZ0ZBPzijo8938iugtVvqi9UgDmnY3u / NlQDqiL5BGqSxSTd / Sgmy
3 zD8PYzEa3wD9vehQ5fZZ45vKIq8GNVh2Z8 + IGO85FF1OsN7 + b2yGJa / FmDDNn0 +
HP + mPfI + kYBqEVpo0Ztbc3UdxgFwGC8O1n8AQyriwHnSOtIiuBH62J / 7 qyC / 3 LEA
ApRbDd9YszqzmODjQUddZKHmvc638VW + azc0EwIDAQABAoIBADZ / QGgUzInvsLp /
zO2WbfYm39o / uhNAvk9RbLt1TIZbMFhyOpeKynHi3Swwd9xsfWX / U9zS / lGi / m31
iKrhmaW4OA1G3vqpMcK7TBbFufYwUEaA + ZJX344euH8pIfdzyneMQ4z3Far2dS7l
QsmjuilVV2kEFadveXewiYoVOWCu00w6bN8wy2SIHlQn + kIL6HQhWz12iKKflIKu
eGRdzLHsKmBt6WbY1Wuhx7HU0fAKdlBDPxCHNlI + kybUYE9o5C2vJiaVM5wqJBgZ
8 Dz8kt1QbLJ910JoLXkLVQ8uC8NJKQwFtqQjTGPnEq0 + wbgz6Ij599rKZkwW / xq9
l6KoUiECgYEA6Ah42tVdkNW047f03xVYXFH96RgorHRS36mR8Y + ONUq1fwKidovC
WjwVujt4OPf3l1W6iyn / F6cu / bsmvPrSc3HTN0B1V31QK4OjgetxQ2PSbTldH02J
NPzkt + v + cPxXpx / P5mgt7Weefw5txU547KubGrHUV5rBKFtIx9pj16MCgYEA / EF0
o19 + D24DZAPwlDS5VbEd7FStnwY4oQ5PqbuNOSbSJLMWU0AqzXcRokp8UTyCZ0X3
ATkS1REq97kShCuR + npTR6a6DlY7sdpPI1SMLNajgB2tkx0EOzX + PfNIbHUd4jpJ
I0ZMAHv / OOtkzQHDaeTWBTrzsWm6 / nTiykfduNECgYEA46AMD4HpPECqKAs66e5i
tI6q7JSKskObWVdcmQEfnSAhVOwcvPb2Ptda6UuV8S0xcwDi88rLOUUFUFzc79 + P
vTkY38cYVi / VChsluDpk7ptqv0PbGu5Rf + 3 n4pZdEjI7OvR2W64wAAn67uIUxc7p
yiO / ET0K9rYWb6S9jXGtKMkCgYEA2kPAqoO7zZoBMQ7 / oR0lp / HC1HRIbiqx4RlC
8 Lgpb + QZPEwA6zPAVVvLVENi4d + bbcRp / xLlKpraNNJcJSSWAMbLPFoU7sbKjA87
HnTPfRSTEA2d3Ibk3F7Rh8TzS3Ti0JZiJjVzGZAwu41iAMifzwaD8K6boUy80eNN
QH2CaaECgYBUsLYvC / MiYg3w + LGOONuQongoVUXjGqnw2bjVa9RK7lwRdXPUqJ51
MpVO98IkoLvGSI / 0 sGNP3GKNhC + eMGjJAVwFyEuOn + JsmMv9Y9uStIVi5tIHIhKw
m7mp8il0kaftHdSxTbspG3tZ2fjIiFIZkLEOmRpd7ogWumgOajzUdA ==
-- -- - END RSA PRIVATE KEY -- -- - ` , {
options : {
environment : "browser" ,
encryptionScheme : "pkcs1_oaep"
}
} ) ;
console . log ( "decryptedWithPrivate" ) ;
console . log ( decryptedWithPrivate ) ;
( ( ) => {
let key = new NODERSA . NodeRSA ( {
b : 1024
} ) ;
key . setOptions ( {
encryptionScheme : "pkcs1"
} ) ;
let text = ` 你好drpy node-ras ` ;
let encrypted = key . encrypt ( text , "base64" ) ;
console . log ( "encrypted: " , encrypted ) ;
const decrypted = key . decrypt ( encrypted , "utf8" ) ;
console . log ( "decrypted: " , decrypted )
} ) ( ) ;
let t2 = ( new Date )
. getTime ( ) ;
console . log ( "rsa_demo_test 测试耗时:" + ( t2 - t1 ) + "毫秒" )
}
2024-05-14 22:28:15 +08:00
function pre ( ) {
if ( typeof rule . 预处理 === "string" && rule . 预处理 && rule . 预处理 . trim ( ) ) {
let code = rule . 预处理 . trim ( ) ;
console . log ( "执行预处理代码:" + code ) ;
if ( code . startsWith ( "js:" ) ) {
code = code . replace ( "js:" , "" )
}
try {
eval ( code )
} catch ( e ) {
console . log ( "预处理执行失败:" + e . message )
}
}
}
let rule = { } ;
let vercode = typeof pdfl === "function" ? "drpy2.1" : "drpy2" ;
2024-05-26 13:39:40 +08:00
const VERSION = vercode + " 3.9.50beta17 202400524" ;
2024-05-14 22:28:15 +08:00
const MOBILE _UA = "Mozilla/5.0 (Linux; Android 11; M2007J3SC Build/RKQ1.200826.002; wv) AppleWebKit/537.36 (KHTML, like Gecko) Version/4.0 Chrome/77.0.3865.120 MQQBrowser/6.2 TBS/045714 Mobile Safari/537.36" ;
const PC _UA = "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/95.0.4638.54 Safari/537.36" ;
const UA = "Mozilla/5.0" ;
const UC _UA = "Mozilla/5.0 (Linux; U; Android 9; zh-CN; MI 9 Build/PKQ1.181121.001) AppleWebKit/537.36 (KHTML, like Gecko) Version/4.0 Chrome/57.0.2987.108 UCBrowser/12.5.5.1035 Mobile Safari/537.36" ;
const IOS _UA = "Mozilla/5.0 (iPhone; CPU iPhone OS 13_2_3 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/13.0.3 Mobile/15E148 Safari/604.1" ;
const RULE _CK = "cookie" ;
const CATE _EXCLUDE = "首页|留言|APP|下载|资讯|新闻|动态" ;
const TAB _EXCLUDE = "猜你|喜欢|下载|剧情|热播" ;
const OCR _RETRY = 3 ;
2024-05-26 13:39:40 +08:00
const OCR _API = "https://api.nn.ci/ocr/b64/text" ;
2024-05-14 22:28:15 +08:00
if ( typeof MY _URL === "undefined" ) {
var MY _URL
}
var HOST ;
var RKEY ;
var fetch ;
var print ;
var log ;
var rule _fetch _params ;
var fetch _params ;
var oheaders ;
var _pdfh ;
var _pdfa ;
var _pd ;
const DOM _CHECK _ATTR = /(url|src|href|-original|-src|-play|-url|style)$/ ;
const SPECIAL _URL = /^(ftp|magnet|thunder|ws):/ ;
const NOADD _INDEX = /:eq|:lt|:gt|:first|:last|^body$|^#/ ;
const URLJOIN _ATTR = /(url|src|href|-original|-src|-play|-url|style)$/ ;
const SELECT _REGEX = /:eq|:lt|:gt|#/g ;
const SELECT _REGEX _A = /:eq|:lt|:gt/g ;
2024-05-26 13:39:40 +08:00
const $js = {
toString ( func ) {
let strfun = func . toString ( ) ;
return strfun . replace ( /^\(\)(\s+)?=>(\s+)?\{/ , "js:" )
. replace ( /\}$/ , "" )
}
} ;
function window _b64 ( ) {
let b64map = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/" ;
let base64DecodeChars = new Array ( - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , 62 , - 1 , - 1 , - 1 , 63 , 52 , 53 , 54 , 55 , 56 , 57 , 58 , 59 , 60 , 61 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , 0 , 1 , 2 , 3 , 4 , 5 , 6 , 7 , 8 , 9 , 10 , 11 , 12 , 13 , 14 , 15 , 16 , 17 , 18 , 19 , 20 , 21 , 22 , 23 , 24 , 25 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , 26 , 27 , 28 , 29 , 30 , 31 , 32 , 33 , 34 , 35 , 36 , 37 , 38 , 39 , 40 , 41 , 42 , 43 , 44 , 45 , 46 , 47 , 48 , 49 , 50 , 51 , - 1 , - 1 , - 1 , - 1 , - 1 ) ;
function btoa ( str ) {
var out , i , len ;
var c1 , c2 , c3 ;
len = str . length ;
i = 0 ;
out = "" ;
while ( i < len ) {
c1 = str . charCodeAt ( i ++ ) & 255 ;
if ( i == len ) {
out += b64map . charAt ( c1 >> 2 ) ;
out += b64map . charAt ( ( c1 & 3 ) << 4 ) ;
out += "==" ;
break
}
c2 = str . charCodeAt ( i ++ ) ;
if ( i == len ) {
out += b64map . charAt ( c1 >> 2 ) ;
out += b64map . charAt ( ( c1 & 3 ) << 4 | ( c2 & 240 ) >> 4 ) ;
out += b64map . charAt ( ( c2 & 15 ) << 2 ) ;
out += "=" ;
break
}
c3 = str . charCodeAt ( i ++ ) ;
out += b64map . charAt ( c1 >> 2 ) ;
out += b64map . charAt ( ( c1 & 3 ) << 4 | ( c2 & 240 ) >> 4 ) ;
out += b64map . charAt ( ( c2 & 15 ) << 2 | ( c3 & 192 ) >> 6 ) ;
out += b64map . charAt ( c3 & 63 )
}
return out
}
function atob ( str ) {
var c1 , c2 , c3 , c4 ;
var i , len , out ;
len = str . length ;
i = 0 ;
out = "" ;
while ( i < len ) {
do {
c1 = base64DecodeChars [ str . charCodeAt ( i ++ ) & 255 ]
} while ( i < len && c1 == - 1 ) ;
if ( c1 == - 1 ) break ;
do {
c2 = base64DecodeChars [ str . charCodeAt ( i ++ ) & 255 ]
} while ( i < len && c2 == - 1 ) ;
if ( c2 == - 1 ) break ;
out += String . fromCharCode ( c1 << 2 | ( c2 & 48 ) >> 4 ) ;
do {
c3 = str . charCodeAt ( i ++ ) & 255 ;
if ( c3 == 61 ) return out ;
c3 = base64DecodeChars [ c3 ]
} while ( i < len && c3 == - 1 ) ;
if ( c3 == - 1 ) break ;
out += String . fromCharCode ( ( c2 & 15 ) << 4 | ( c3 & 60 ) >> 2 ) ;
do {
c4 = str . charCodeAt ( i ++ ) & 255 ;
if ( c4 == 61 ) return out ;
c4 = base64DecodeChars [ c4 ]
} while ( i < len && c4 == - 1 ) ;
if ( c4 == - 1 ) break ;
out += String . fromCharCode ( ( c3 & 3 ) << 6 | c4 )
}
return out
}
return {
atob : atob ,
btoa : btoa
}
}
if ( typeof atob != "function" || typeof btoa != "function" ) {
var {
atob , btoa
} = window _b64 ( )
}
2024-05-14 22:28:15 +08:00
if ( typeof Object . assign != "function" ) {
Object . assign = function ( ) {
let target = arguments [ 0 ] ;
for ( let i = 1 ; i < arguments . length ; i ++ ) {
let source = arguments [ i ] ;
for ( let key in source ) {
if ( Object . prototype . hasOwnProperty . call ( source , key ) ) {
target [ key ] = source [ key ]
}
}
}
return target
}
}
if ( ! String . prototype . includes ) {
String . prototype . includes = function ( search , start ) {
if ( typeof start !== "number" ) {
start = 0
}
if ( start + search . length > this . length ) {
return false
} else {
return this . indexOf ( search , start ) !== - 1
}
}
}
if ( ! Array . prototype . includes ) {
Object . defineProperty ( Array . prototype , "includes" , {
value : function ( searchElement , fromIndex ) {
if ( this == null ) {
throw new TypeError ( '"this" is null or not defined' )
}
var o = Object ( this ) ;
var len = o . length >>> 0 ;
if ( len === 0 ) {
return false
}
var n = fromIndex | 0 ;
var k = Math . max ( n >= 0 ? n : len - Math . abs ( n ) , 0 ) ;
while ( k < len ) {
if ( o [ k ] === searchElement ) {
return true
}
k ++
}
return false
2024-05-26 13:39:40 +08:00
} ,
enumerable : false
2024-05-14 22:28:15 +08:00
} )
}
if ( typeof String . prototype . startsWith != "function" ) {
String . prototype . startsWith = function ( prefix ) {
return this . slice ( 0 , prefix . length ) === prefix
}
}
if ( typeof String . prototype . endsWith != "function" ) {
String . prototype . endsWith = function ( suffix ) {
return this . indexOf ( suffix , this . length - suffix . length ) !== - 1
}
}
2024-05-26 13:39:40 +08:00
Object . defineProperty ( Object . prototype , "myValues" , {
value : function ( obj ) {
2024-05-14 22:28:15 +08:00
if ( obj == null ) {
throw new TypeError ( "Cannot convert undefined or null to object" )
}
var res = [ ] ;
for ( var k in obj ) {
if ( obj . hasOwnProperty ( k ) ) {
res . push ( obj [ k ] )
}
}
return res
2024-05-26 13:39:40 +08:00
} ,
enumerable : false
} ) ;
if ( typeof Object . prototype . values != "function" ) {
Object . defineProperty ( Object . prototype , "values" , {
value : function ( obj ) {
if ( obj == null ) {
throw new TypeError ( "Cannot convert undefined or null to object" )
}
var res = [ ] ;
for ( var k in obj ) {
if ( obj . hasOwnProperty ( k ) ) {
res . push ( obj [ k ] )
}
}
return res
} ,
enumerable : false
} )
2024-05-14 22:28:15 +08:00
}
if ( typeof Array . prototype . join != "function" ) {
2024-05-26 13:39:40 +08:00
Object . defineProperty ( Array . prototype , "join" , {
value : function ( emoji ) {
emoji = emoji || "" ;
let self = this ;
let str = "" ;
let i = 0 ;
if ( ! Array . isArray ( self ) ) {
throw String ( self ) + "is not Array"
}
if ( self . length === 0 ) {
return ""
}
if ( self . length === 1 ) {
return String ( self [ 0 ] )
}
i = 1 ;
str = this [ 0 ] ;
for ( ; i < self . length ; i ++ ) {
str += String ( emoji ) + String ( self [ i ] )
}
return str
} ,
enumerable : false
} )
2024-05-14 22:28:15 +08:00
}
if ( typeof Array . prototype . toReversed != "function" ) {
2024-05-26 13:39:40 +08:00
Object . defineProperty ( Array . prototype , "toReversed" , {
value : function ( ) {
const clonedList = this . slice ( ) ;
const reversedList = clonedList . reverse ( ) ;
return reversedList
} ,
enumerable : false
} )
2024-05-14 22:28:15 +08:00
}
2024-05-26 13:39:40 +08:00
Object . defineProperty ( Array . prototype , "append" , {
value : Array . prototype . push ,
enumerable : false
} ) ;
Object . defineProperty ( String . prototype , "strip" , {
value : String . prototype . trim ,
enumerable : false
} ) ;
Object . defineProperty ( String . prototype , "rstrip" , {
value : function ( chars ) {
let regex = new RegExp ( chars + "$" ) ;
return this . replace ( regex , "" )
} ,
enumerable : false
} ) ;
2024-05-14 22:28:15 +08:00
function 是否正版 ( vipUrl ) {
let flag = new RegExp ( "qq.com|iqiyi.com|youku.com|mgtv.com|bilibili.com|sohu.com|ixigua.com|pptv.com|miguvideo.com|le.com|1905.com|fun.tv" ) ;
return flag . test ( vipUrl )
}
function urlDeal ( vipUrl ) {
if ( ! vipUrl ) {
return ""
}
if ( ! 是否正版 ( vipUrl ) ) {
return vipUrl
}
if ( ! /miguvideo/ . test ( vipUrl ) ) {
vipUrl = vipUrl . split ( "#" ) [ 0 ] . split ( "?" ) [ 0 ]
}
return vipUrl
}
function setResult ( d ) {
if ( ! Array . isArray ( d ) ) {
return [ ]
}
VODS = [ ] ;
d . forEach ( function ( it ) {
let obj = {
vod _id : it . url || "" ,
vod _name : it . title || "" ,
vod _remarks : it . desc || "" ,
vod _content : it . content || "" ,
vod _pic : it . pic _url || it . img || ""
} ;
let keys = Object . keys ( it ) ;
if ( keys . includes ( "tname" ) ) {
obj . type _name = it . tname || ""
}
if ( keys . includes ( "tid" ) ) {
obj . type _id = it . tid || ""
}
if ( keys . includes ( "year" ) ) {
obj . vod _year = it . year || ""
}
if ( keys . includes ( "actor" ) ) {
obj . vod _actor = it . actor || ""
}
if ( keys . includes ( "director" ) ) {
obj . vod _director = it . director || ""
}
if ( keys . includes ( "area" ) ) {
obj . vod _area = it . area || ""
}
VODS . push ( obj )
} ) ;
return VODS
}
function setResult2 ( res ) {
VODS = res . list || [ ] ;
return VODS
}
function setHomeResult ( res ) {
if ( ! res || typeof res !== "object" ) {
return [ ]
}
return setResult ( res . list )
}
function rc ( js ) {
if ( js === "maomi_aes.js" ) {
var a = CryptoJS . enc . Utf8 . parse ( "625222f9149e961d" ) ;
var t = CryptoJS . enc . Utf8 . parse ( "5efdtf6060e2o330" ) ;
return {
De : function ( word ) {
word = CryptoJS . enc . Hex . parse ( word ) ;
return CryptoJS . AES . decrypt ( CryptoJS . enc . Base64 . stringify ( word ) , a , {
iv : t ,
mode : CryptoJS . mode . CBC ,
padding : CryptoJS . pad . Pkcs7
} )
. toString ( CryptoJS . enc . Utf8 )
} ,
En : function ( word ) {
var Encrypted = CryptoJS . AES . encrypt ( word , a , {
iv : t ,
mode : CryptoJS . mode . CBC ,
padding : CryptoJS . pad . Pkcs7
} ) ;
return Encrypted . ciphertext . toString ( )
}
}
}
return { }
}
function maoss ( jxurl , ref , key ) {
fetch _params = JSON . parse ( JSON . stringify ( rule _fetch _params ) ) ;
eval ( getCryptoJS ( ) ) ;
try {
var getVideoInfo = function ( text ) {
return CryptoJS . AES . decrypt ( text , key , {
iv : iv ,
padding : CryptoJS . pad . Pkcs7
} )
. toString ( CryptoJS . enc . Utf8 )
} ;
var token _key = key == undefined ? "dvyYRQlnPRCMdQSe" : key ;
if ( ref ) {
var html = request ( jxurl , {
headers : {
Referer : ref
}
} )
} else {
var html = request ( jxurl )
}
if ( html . indexOf ( "&btwaf=" ) != - 1 ) {
html = request ( jxurl + "&btwaf" + html . match ( /&btwaf(.*?)"/ ) [ 1 ] , {
headers : {
Referer : ref
}
} )
}
var token _iv = html . split ( '_token = "' ) [ 1 ] . split ( '"' ) [ 0 ] ;
var key = CryptoJS . enc . Utf8 . parse ( token _key ) ;
var iv = CryptoJS . enc . Utf8 . parse ( token _iv ) ;
eval ( html . match ( /var config = {[\s\S]*?}/ ) [ 0 ] + "" ) ;
if ( ! config . url . startsWith ( "http" ) ) {
config . url = CryptoJS . AES . decrypt ( config . url , key , {
iv : iv ,
padding : CryptoJS . pad . Pkcs7
} )
. toString ( CryptoJS . enc . Utf8 )
}
return config . url
} catch ( e ) {
return ""
}
}
function urlencode ( str ) {
str = ( str + "" )
. toString ( ) ;
return encodeURIComponent ( str )
. replace ( /!/g , "%21" )
. replace ( /'/g , "%27" )
. replace ( /\(/g , "%28" )
. replace ( /\)/g , "%29" )
. replace ( /\*/g , "%2A" )
. replace ( /%20/g , "+" )
}
function base64Encode ( text ) {
return CryptoJS . enc . Base64 . stringify ( CryptoJS . enc . Utf8 . parse ( text ) )
}
function base64Decode ( text ) {
return CryptoJS . enc . Utf8 . stringify ( CryptoJS . enc . Base64 . parse ( text ) )
}
function md5 ( text ) {
return CryptoJS . MD5 ( text )
. toString ( )
}
2024-05-26 13:39:40 +08:00
function uint8ArrayToBase64 ( uint8Array ) {
let binaryString = String . fromCharCode . apply ( null , Array . from ( uint8Array ) ) ;
return btoa ( binaryString )
}
function Utf8ArrayToStr ( array ) {
var out , i , len , c ;
var char2 , char3 ;
out = "" ;
len = array . length ;
i = 0 ;
while ( i < len ) {
c = array [ i ++ ] ;
switch ( c >> 4 ) {
case 0 :
case 1 :
case 2 :
case 3 :
case 4 :
case 5 :
case 6 :
case 7 :
out += String . fromCharCode ( c ) ;
break ;
case 12 :
case 13 :
char2 = array [ i ++ ] ;
out += String . fromCharCode ( ( c & 31 ) << 6 | char2 & 63 ) ;
break ;
case 14 :
char2 = array [ i ++ ] ;
char3 = array [ i ++ ] ;
out += String . fromCharCode ( ( c & 15 ) << 12 | ( char2 & 63 ) << 6 | ( char3 & 63 ) << 0 ) ;
break
}
}
return out
}
function gzip ( str ) {
let arr = pako . gzip ( str , {
to : "string"
} ) ;
return uint8ArrayToBase64 ( arr )
}
function ungzip ( b64Data ) {
let strData = atob ( b64Data ) ;
const charData = strData . split ( "" )
. map ( function ( x ) {
return x . charCodeAt ( 0 )
} ) ;
const binData = new Uint8Array ( charData ) ;
const data = pako . inflate ( binData ) ;
return Utf8ArrayToStr ( data )
}
2024-05-14 22:28:15 +08:00
function encodeStr ( input , encoding ) {
encoding = encoding || "gbk" ;
if ( encoding . startsWith ( "gb" ) ) {
const strTool = gbkTool ( ) ;
input = strTool . encode ( input )
}
return input
}
function decodeStr ( input , encoding ) {
encoding = encoding || "gbk" ;
if ( encoding . startsWith ( "gb" ) ) {
const strTool = gbkTool ( ) ;
input = strTool . decode ( input )
}
return input
}
function getCryptoJS ( ) {
return 'console.log("CryptoJS已装载");'
}
const RSA = {
decode : function ( data , key , option ) {
option = option || { } ;
if ( typeof JSEncrypt === "function" ) {
let chunkSize = option . chunkSize || 117 ;
let privateKey = this . getPrivateKey ( key ) ;
const decryptor = new JSEncrypt ;
decryptor . setPrivateKey ( privateKey ) ;
let uncrypted = "" ;
uncrypted = decryptor . decryptUnicodeLong ( data ) ;
return uncrypted
} else {
return false
}
} ,
encode : function ( data , key , option ) {
option = option || { } ;
if ( typeof JSEncrypt === "function" ) {
let chunkSize = option . chunkSize || 117 ;
let publicKey = this . getPublicKey ( key ) ;
const encryptor = new JSEncrypt ;
encryptor . setPublicKey ( publicKey ) ;
let encrypted = "" ;
encrypted = encryptor . encryptUnicodeLong ( data ) ;
return encrypted
} else {
return false
}
} ,
fixKey ( key , prefix , endfix ) {
if ( ! key . includes ( prefix ) ) {
key = prefix + key
}
if ( ! key . includes ( endfix ) ) {
key += endfix
}
return key
} ,
getPrivateKey ( key ) {
let prefix = "-----BEGIN RSA PRIVATE KEY-----" ;
let endfix = "-----END RSA PRIVATE KEY-----" ;
return this . fixKey ( key , prefix , endfix )
} ,
getPublicKey ( key ) {
let prefix = "-----BEGIN PUBLIC KEY-----" ;
let endfix = "-----END PUBLIC KEY-----" ;
return this . fixKey ( key , prefix , endfix )
}
} ;
function getProxyUrl ( ) {
if ( typeof getProxy === "function" ) {
return getProxy ( true )
} else {
return "http://127.0.0.1:9978/proxy?do=js"
}
}
function fixAdM3u8 ( m3u8 _text , m3u8 _url , ad _remove ) {
if ( ! m3u8 _text && ! m3u8 _url || ! m3u8 _text && m3u8 _url && ! m3u8 _url . startsWith ( "http" ) ) {
return ""
}
if ( ! m3u8 _text ) {
log ( "m3u8_url:" + m3u8 _url ) ;
m3u8 _text = request ( m3u8 _url )
}
log ( "len(m3u8_text):" + m3u8 _text . length ) ;
if ( ! ad _remove ) {
return m3u8 _text
}
if ( ad _remove . startsWith ( "reg:" ) ) {
ad _remove = ad _remove . slice ( 4 )
} else if ( ad _remove . startsWith ( "js:" ) ) {
ad _remove = ad _remove . slice ( 3 )
}
let m3u8 _start = m3u8 _text . slice ( 0 , m3u8 _text . indexOf ( "#EXTINF" ) )
. trim ( ) ;
let m3u8 _body = m3u8 _text . slice ( m3u8 _text . indexOf ( "#EXTINF" ) , m3u8 _text . indexOf ( "#EXT-X-ENDLIST" ) )
. trim ( ) ;
let m3u8 _end = m3u8 _text . slice ( m3u8 _text . indexOf ( "#EXT-X-ENDLIST" ) )
. trim ( ) ;
let murls = [ ] ;
let m3 _body _list = m3u8 _body . split ( "\n" ) ;
let m3 _len = m3 _body _list . length ;
let i = 0 ;
while ( i < m3 _len ) {
let mi = m3 _body _list [ i ] ;
let mi _1 = m3 _body _list [ i + 1 ] ;
if ( mi . startsWith ( "#EXTINF" ) ) {
murls . push ( [ mi , mi _1 ] . join ( "&" ) ) ;
i += 2
} else if ( mi . startsWith ( "#EXT-X-DISCONTINUITY" ) ) {
let mi _2 = m3 _body _list [ i + 2 ] ;
murls . push ( [ mi , mi _1 , mi _2 ] . join ( "&" ) ) ;
i += 3
} else {
break
}
}
let new _m3u8 _body = [ ] ;
for ( let murl of murls ) {
if ( ad _remove && new RegExp ( ad _remove )
. test ( murl ) ) { } else {
let murl _list = murl . split ( "&" ) ;
if ( ! murl _list [ murl _list . length - 1 ] . startsWith ( "http" ) && m3u8 _url . startsWith ( "http" ) ) {
murl _list [ murl _list . length - 1 ] = urljoin ( m3u8 _url , murl _list [ murl _list . length - 1 ] )
}
murl _list . forEach ( it => {
new _m3u8 _body . push ( it )
} )
}
}
new _m3u8 _body = new _m3u8 _body . join ( "\n" )
. trim ( ) ;
m3u8 _text = [ m3u8 _start , new _m3u8 _body , m3u8 _end ] . join ( "\n" )
. trim ( ) ;
return m3u8 _text
}
2024-05-26 13:39:40 +08:00
function fixAdM3u8Ai ( m3u8 _url , headers ) {
2024-05-14 22:28:15 +08:00
let ts = ( new Date )
. getTime ( ) ;
2024-05-26 13:39:40 +08:00
let option = headers ? {
headers : headers
} : { } ;
2024-05-14 22:28:15 +08:00
function b ( s1 , s2 ) {
let i = 0 ;
while ( i < s1 . length ) {
if ( s1 [ i ] !== s2 [ i ] ) {
break
}
i ++
}
return i
}
function reverseString ( str ) {
return str . split ( "" )
. reverse ( )
. join ( "" )
}
2024-05-26 13:39:40 +08:00
let m3u8 = request ( m3u8 _url , option ) ;
2024-05-14 22:28:15 +08:00
m3u8 = m3u8 . trim ( )
. split ( "\n" )
. map ( it => it . startsWith ( "#" ) ? it : urljoin ( m3u8 _url , it ) )
. join ( "\n" ) ;
2024-05-26 13:39:40 +08:00
m3u8 = m3u8 . replace ( /\n\n/gi , "\n" ) ;
2024-05-14 22:28:15 +08:00
let last _url = m3u8 . split ( "\n" )
. slice ( - 1 ) [ 0 ] ;
2024-05-26 13:39:40 +08:00
if ( last _url . length < 5 ) {
last _url = m3u8 . split ( "\n" )
. slice ( - 2 ) [ 0 ]
}
2024-05-14 22:28:15 +08:00
if ( last _url . includes ( ".m3u8" ) && last _url !== m3u8 _url ) {
2024-05-26 13:39:40 +08:00
m3u8 _url = urljoin2 ( m3u8 _url , last _url ) ;
log ( "嵌套的m3u8_url:" + m3u8 _url ) ;
m3u8 = request ( m3u8 _url , option )
2024-05-14 22:28:15 +08:00
}
let s = m3u8 . trim ( )
. split ( "\n" )
. filter ( it => it . trim ( ) )
. join ( "\n" ) ;
let ss = s . split ( "\n" ) ;
let firststr = ss . find ( x => ! x . startsWith ( "#" ) ) ;
let maxl = 0 ;
let firststrlen = firststr . length ;
let ml = Math . round ( ss . length / 2 )
. toString ( )
. length ;
2024-05-26 13:39:40 +08:00
let maxc = 0 ;
2024-05-14 22:28:15 +08:00
let laststr = ss . toReversed ( )
. find ( x => {
if ( ! x . startsWith ( "#" ) ) {
let k = b ( reverseString ( firststr ) , reverseString ( x ) ) ;
maxl = b ( firststr , x ) ;
2024-05-26 13:39:40 +08:00
maxc ++ ;
if ( firststrlen - maxl <= ml + k || maxc > 10 ) {
2024-05-14 22:28:15 +08:00
return true
}
}
return false
} ) ;
log ( "最后一条切片:" + laststr ) ;
let ad _urls = [ ] ;
for ( let i = 0 ; i < ss . length ; i ++ ) {
let s = ss [ i ] ;
if ( ! s . startsWith ( "#" ) ) {
if ( b ( firststr , s ) < maxl ) {
ad _urls . push ( s ) ;
ss . splice ( i - 1 , 2 ) ;
i = i - 2
} else {
ss [ i ] = urljoin ( m3u8 _url , s )
}
} else {
ss [ i ] = s . replace ( /URI=\"(.*)\"/ , 'URI="' + urljoin ( m3u8 _url , "$1" ) + '"' )
}
}
log ( "处理的m3u8地址:" + m3u8 _url ) ;
log ( "----广告地址----" ) ;
log ( ad _urls ) ;
m3u8 = ss . join ( "\n" ) ;
log ( "处理耗时:" + ( ( new Date )
. getTime ( ) - ts )
. toString ( ) ) ;
return m3u8
}
function forceOrder ( lists , key , option ) {
let start = Math . floor ( lists . length / 2 ) ;
let end = Math . min ( lists . length - 1 , start + 1 ) ;
if ( start >= end ) {
return lists
}
let first = lists [ start ] ;
let second = lists [ end ] ;
if ( key ) {
try {
first = first [ key ] ;
second = second [ key ]
} catch ( e ) { }
}
if ( option && typeof option === "function" ) {
try {
first = option ( first ) ;
second = option ( second )
} catch ( e ) { }
}
first += "" ;
second += "" ;
if ( first . match ( /(\d+)/ ) && second . match ( /(\d+)/ ) ) {
let num1 = Number ( first . match ( /(\d+)/ ) [ 1 ] ) ;
let num2 = Number ( second . match ( /(\d+)/ ) [ 1 ] ) ;
if ( num1 > num2 ) {
lists . reverse ( )
}
}
return lists
}
let VODS = [ ] ;
let VOD = { } ;
let TABS = [ ] ;
let LISTS = [ ] ;
globalThis . encodeUrl = urlencode ;
globalThis . urlencode = urlencode ;
2024-05-26 13:39:40 +08:00
function getQuery ( url ) {
try {
if ( url . indexOf ( "?" ) > - 1 ) {
url = url . slice ( url . indexOf ( "?" ) + 1 )
}
let arr = url . split ( "#" ) [ 0 ] . split ( "&" ) ;
const resObj = { } ;
arr . forEach ( item => {
let arr1 = item . split ( "=" ) ;
let key = arr1 [ 0 ] ;
let value = arr1 . slice ( 1 )
. join ( "=" ) ;
resObj [ key ] = value
} ) ;
return resObj
} catch ( err ) {
log ( "getQuery发生错误:" + e . message ) ;
return { }
}
}
2024-05-14 22:28:15 +08:00
function urljoin ( fromPath , nowPath ) {
fromPath = fromPath || "" ;
nowPath = nowPath || "" ;
return joinUrl ( fromPath , nowPath )
}
var urljoin2 = urljoin ;
const defaultParser = {
pdfh : pdfh ,
pdfa : pdfa ,
pd : pd
} ;
function pdfh2 ( html , parse ) {
let html2 = html ;
try {
if ( typeof html !== "string" ) {
html2 = html . rr ( html . ele )
. toString ( )
}
} catch ( e ) {
print ( "html对象转文本发生了错误:" + e . message )
}
let result = defaultParser . pdfh ( html2 , parse ) ;
let option = parse . includes ( "&&" ) ? parse . split ( "&&" )
. slice ( - 1 ) [ 0 ] : parse . split ( " " )
. slice ( - 1 ) [ 0 ] ;
if ( /style/ . test ( option . toLowerCase ( ) ) && /url\(/ . test ( result ) ) {
try {
result = result . match ( /url\((.*?)\)/ ) [ 1 ] ;
result = result . replace ( /^['|"](.*)['|"]$/ , "$1" )
} catch ( e ) { }
}
return result
}
function pdfa2 ( html , parse ) {
let html2 = html ;
try {
if ( typeof html !== "string" ) {
html2 = html . rr ( html . ele )
. toString ( )
}
} catch ( e ) {
print ( "html对象转文本发生了错误:" + e . message )
}
return defaultParser . pdfa ( html2 , parse )
}
function pd2 ( html , parse , uri ) {
let ret = pdfh2 ( html , parse ) ;
if ( typeof uri === "undefined" || ! uri ) {
uri = ""
}
if ( DOM _CHECK _ATTR . test ( parse ) && ! SPECIAL _URL . test ( ret ) ) {
if ( /http/ . test ( ret ) ) {
ret = ret . slice ( ret . indexOf ( "http" ) )
} else {
ret = urljoin ( MY _URL , ret )
}
}
return ret
}
const parseTags = {
jsp : {
pdfh : pdfh2 ,
pdfa : pdfa2 ,
pd : pd2
} ,
json : {
pdfh ( html , parse ) {
if ( ! parse || ! parse . trim ( ) ) {
return ""
}
if ( typeof html === "string" ) {
html = JSON . parse ( html )
}
parse = parse . trim ( ) ;
if ( ! parse . startsWith ( "$." ) ) {
parse = "$." + parse
}
parse = parse . split ( "||" ) ;
for ( let ps of parse ) {
let ret = cheerio . jp ( ps , html ) ;
if ( Array . isArray ( ret ) ) {
ret = ret [ 0 ] || ""
} else {
ret = ret || ""
}
if ( ret && typeof ret !== "string" ) {
ret = ret . toString ( )
}
if ( ret ) {
return ret
}
}
return ""
} , pdfa ( html , parse ) {
if ( ! parse || ! parse . trim ( ) ) {
return ""
}
if ( typeof html === "string" ) {
html = JSON . parse ( html )
}
parse = parse . trim ( ) ;
if ( ! parse . startsWith ( "$." ) ) {
parse = "$." + parse
}
let ret = cheerio . jp ( parse , html ) ;
if ( Array . isArray ( ret ) && Array . isArray ( ret [ 0 ] ) && ret . length === 1 ) {
return ret [ 0 ] || [ ]
}
return ret || [ ]
} , pd ( html , parse ) {
let ret = parseTags . json . pdfh ( html , parse ) ;
if ( ret ) {
return urljoin ( MY _URL , ret )
}
return ret
}
} ,
jq : {
pdfh ( html , parse ) {
if ( ! html || ! parse || ! parse . trim ( ) ) {
return ""
}
parse = parse . trim ( ) ;
let result = defaultParser . pdfh ( html , parse ) ;
return result
} , pdfa ( html , parse ) {
if ( ! html || ! parse || ! parse . trim ( ) ) {
return [ ]
}
parse = parse . trim ( ) ;
let result = defaultParser . pdfa ( html , parse ) ;
print ( ` pdfa解析 ${ parse } => ${ result . length } ` ) ;
return result
} , pd ( html , parse , base _url ) {
if ( ! html || ! parse || ! parse . trim ( ) ) {
return ""
}
parse = parse . trim ( ) ;
base _url = base _url || MY _URL ;
return defaultParser . pd ( html , parse , base _url )
}
} ,
getParse ( p0 ) {
if ( p0 . startsWith ( "jsp:" ) ) {
return this . jsp
} else if ( p0 . startsWith ( "json:" ) ) {
return this . json
} else if ( p0 . startsWith ( "jq:" ) ) {
return this . jq
} else {
return this . jq
}
}
} ;
const stringify = JSON . stringify ;
const jsp = parseTags . jsp ;
const jq = parseTags . jq ;
function readFile ( filePath ) {
filePath = filePath || "./uri.min.js" ;
var fd = os . open ( filePath ) ;
var buffer = new ArrayBuffer ( 1024 ) ;
var len = os . read ( fd , buffer , 0 , 1024 ) ;
console . log ( len ) ;
let text = String . fromCharCode . apply ( null , new Uint8Array ( buffer ) ) ;
console . log ( text ) ;
return text
}
function dealJson ( html ) {
try {
html = html . trim ( ) ;
if ( ! ( html . startsWith ( "{" ) && html . endsWith ( "}" ) || html . startsWith ( "[" ) && html . endsWith ( "]" ) ) ) {
html = "{" + html . match ( /.*?\{(.*)\}/m ) [ 1 ] + "}"
}
} catch ( e ) { }
try {
html = JSON . parse ( html )
} catch ( e ) { }
return html
}
var OcrApi = {
api : OCR _API ,
classification : function ( img ) {
let code = "" ;
try {
log ( "通过drpy_ocr验证码接口过验证..." ) ;
2024-05-26 13:39:40 +08:00
let html = "" ;
if ( this . api . endsWith ( "drpy/text" ) ) {
html = request ( this . api , {
data : {
img : img
} ,
headers : {
"User-Agent" : PC _UA
} ,
method : "POST"
} , true )
} else {
html = post ( this . api , {
body : img
} )
}
2024-05-14 22:28:15 +08:00
code = html || ""
} catch ( e ) {
log ( ` OCR识别验证码发生错误: ${ e . message } ` )
}
return code
}
} ;
function verifyCode ( url ) {
let cnt = 0 ;
let host = getHome ( url ) ;
let cookie = "" ;
while ( cnt < OCR _RETRY ) {
try {
let yzm _url = ` ${ host } /index.php/verify/index.html ` ;
console . log ( ` 验证码链接: ${ yzm _url } ` ) ;
let hhtml = request ( yzm _url , {
withHeaders : true ,
toBase64 : true
} , true ) ;
let json = JSON . parse ( hhtml ) ;
if ( ! cookie ) {
let setCk = Object . keys ( json )
. find ( it => it . toLowerCase ( ) === "set-cookie" ) ;
cookie = setCk ? json [ setCk ] . split ( ";" ) [ 0 ] : ""
}
console . log ( "cookie:" + cookie ) ;
let img = json . body ;
let code = OcrApi . classification ( img ) ;
console . log ( ` 第 ${ cnt + 1 } 次验证码识别结果: ${ code } ` ) ;
let submit _url = ` ${ host } /index.php/ajax/verify_check?type=search&verify= ${ code } ` ;
console . log ( submit _url ) ;
let html = request ( submit _url , {
headers : {
Cookie : cookie ,
"User-Agent" : MOBILE _UA
} ,
method : "POST"
} ) ;
html = JSON . parse ( html ) ;
if ( html . msg === "ok" ) {
console . log ( ` 第 ${ cnt + 1 } 次验证码提交成功 ` ) ;
return cookie
} else if ( html . msg !== "ok" && cnt + 1 >= OCR _RETRY ) {
cookie = ""
}
} catch ( e ) {
console . log ( ` 第 ${ cnt + 1 } 次验证码提交失败: ${ e . message } ` ) ;
if ( cnt + 1 >= OCR _RETRY ) {
cookie = ""
}
}
cnt += 1
}
return cookie
}
function setItem ( k , v ) {
local . set ( RKEY , k , v ) ;
console . log ( ` 规则 ${ RKEY } 设置 ${ k } => ${ v } ` )
}
function getItem ( k , v ) {
return local . get ( RKEY , k ) || v
}
function clearItem ( k ) {
local . delete ( RKEY , k )
}
function getHome ( url ) {
if ( ! url ) {
return ""
}
let tmp = url . split ( "//" ) ;
url = tmp [ 0 ] + "//" + tmp [ 1 ] . split ( "/" ) [ 0 ] ;
try {
url = decodeURIComponent ( url )
} catch ( e ) { }
return url
}
function buildUrl ( url , obj ) {
obj = obj || { } ;
if ( url . indexOf ( "?" ) < 0 ) {
url += "?"
}
let param _list = [ ] ;
let keys = Object . keys ( obj ) ;
keys . forEach ( it => {
param _list . push ( it + "=" + obj [ it ] )
} ) ;
let prs = param _list . join ( "&" ) ;
if ( keys . length > 0 && ! url . endsWith ( "?" ) ) {
url += "&"
}
url += prs ;
return url
}
2024-05-26 13:39:40 +08:00
function $require ( url ) {
2024-05-14 22:28:15 +08:00
eval ( request ( url ) )
}
function request ( url , obj , ocr _flag ) {
ocr _flag = ocr _flag || false ;
if ( typeof obj === "undefined" || ! obj || obj === { } ) {
if ( ! fetch _params || ! fetch _params . headers ) {
let headers = {
"User-Agent" : MOBILE _UA
} ;
if ( rule . headers ) {
Object . assign ( headers , rule . headers )
}
if ( ! fetch _params ) {
fetch _params = { }
}
fetch _params . headers = headers
}
if ( ! fetch _params . headers . Referer ) {
fetch _params . headers . Referer = getHome ( url )
}
obj = fetch _params
} else {
let headers = obj . headers || { } ;
let keys = Object . keys ( headers )
. map ( it => it . toLowerCase ( ) ) ;
if ( ! keys . includes ( "user-agent" ) ) {
headers [ "User-Agent" ] = MOBILE _UA
}
if ( ! keys . includes ( "referer" ) ) {
headers [ "Referer" ] = getHome ( url )
}
obj . headers = headers
}
if ( rule . encoding && rule . encoding !== "utf-8" && ! ocr _flag ) {
if ( ! obj . headers . hasOwnProperty ( "Content-Type" ) && ! obj . headers . hasOwnProperty ( "content-type" ) ) {
obj . headers [ "Content-Type" ] = "text/html; charset=" + rule . encoding
}
}
if ( typeof obj . body != "undefined" && obj . body && typeof obj . body === "string" ) {
if ( ! obj . headers . hasOwnProperty ( "Content-Type" ) && ! obj . headers . hasOwnProperty ( "content-type" ) ) {
obj . headers [ "Content-Type" ] = "application/x-www-form-urlencoded; charset=" + rule . encoding
}
} else if ( typeof obj . body != "undefined" && obj . body && typeof obj . body === "object" ) {
obj . data = obj . body ;
delete obj . body
}
if ( ! url ) {
return obj . withHeaders ? "{}" : ""
}
if ( obj . toBase64 ) {
obj . buffer = 2 ;
delete obj . toBase64
}
if ( obj . redirect === false ) {
obj . redirect = 0
}
console . log ( JSON . stringify ( obj . headers ) ) ;
console . log ( "request:" + url + ` |method: ${ obj . method || "GET" } |body: ${ obj . body || "" } ` ) ;
let res = req ( url , obj ) ;
let html = res . content || "" ;
if ( obj . withHeaders ) {
let htmlWithHeaders = res . headers ;
htmlWithHeaders . body = html ;
return JSON . stringify ( htmlWithHeaders )
} else {
return html
}
}
function post ( url , obj ) {
obj . method = "POST" ;
return request ( url , obj )
}
2024-05-26 13:39:40 +08:00
function reqCookie ( url , obj , all _cookie ) {
obj = obj || { } ;
obj . withHeaders = true ;
all _cookie = all _cookie || false ;
let html = request ( url , obj ) ;
let json = JSON . parse ( html ) ;
let setCk = Object . keys ( json )
. find ( it => it . toLowerCase ( ) === "set-cookie" ) ;
let cookie = setCk ? json [ setCk ] : "" ;
if ( Array . isArray ( cookie ) ) {
cookie = cookie . join ( ";" )
}
if ( ! all _cookie ) {
cookie = cookie . split ( ";" ) [ 0 ]
}
html = json . body ;
return {
cookie : cookie ,
html : html
}
}
2024-05-14 22:28:15 +08:00
fetch = request ;
print = function ( data ) {
data = data || "" ;
if ( typeof data == "object" && Object . keys ( data )
. length > 0 ) {
try {
data = JSON . stringify ( data ) ;
console . log ( data )
} catch ( e ) {
console . log ( typeof data + ":" + data . length ) ;
return
}
} else if ( typeof data == "object" && Object . keys ( data )
. length < 1 ) {
console . log ( "null object" )
} else {
console . log ( data )
}
} ;
log = print ;
function checkHtml ( html , url , obj ) {
if ( /\?btwaf=/ . test ( html ) ) {
let btwaf = html . match ( /btwaf(.*?)"/ ) [ 1 ] ;
url = url . split ( "#" ) [ 0 ] + "?btwaf" + btwaf ;
print ( "宝塔验证访问链接:" + url ) ;
html = request ( url , obj )
}
return html
}
function getCode ( url , obj ) {
let html = request ( url , obj ) ;
html = checkHtml ( html , url , obj ) ;
return html
}
function getHtml ( url ) {
let obj = { } ;
if ( rule . headers ) {
obj . headers = rule . headers
}
let cookie = getItem ( RULE _CK , "" ) ;
if ( cookie ) {
if ( obj . headers && ! Object . keys ( obj . headers )
. map ( it => it . toLowerCase ( ) )
. includes ( "cookie" ) ) {
log ( "历史无cookie,新增过验证后的cookie" ) ;
obj . headers [ "Cookie" ] = cookie
} else if ( obj . headers && obj . headers . cookie && obj . headers . cookie !== cookie ) {
obj . headers [ "Cookie" ] = cookie ;
log ( "历史有小写过期的cookie,更新过验证后的cookie" )
} else if ( obj . headers && obj . headers . Cookie && obj . headers . Cookie !== cookie ) {
obj . headers [ "Cookie" ] = cookie ;
log ( "历史有大写过期的cookie,更新过验证后的cookie" )
} else if ( ! obj . headers ) {
obj . headers = {
Cookie : cookie
} ;
log ( "历史无headers,更新过验证后的含cookie的headers" )
}
}
let html = getCode ( url , obj ) ;
return html
}
function homeParse ( homeObj ) {
fetch _params = JSON . parse ( JSON . stringify ( rule _fetch _params ) ) ;
let classes = [ ] ;
if ( homeObj . class _name && homeObj . class _url ) {
let names = homeObj . class _name . split ( "&" ) ;
let urls = homeObj . class _url . split ( "&" ) ;
let cnt = Math . min ( names . length , urls . length ) ;
for ( let i = 0 ; i < cnt ; i ++ ) {
classes . push ( {
type _id : urls [ i ] ,
type _name : names [ i ]
} )
}
}
if ( homeObj . class _parse ) {
if ( homeObj . class _parse . startsWith ( "js:" ) ) {
var input = homeObj . MY _URL ;
try {
eval ( homeObj . class _parse . replace ( "js:" , "" ) ) ;
if ( Array . isArray ( input ) ) {
classes = input
}
} catch ( e ) {
log ( "通过js动态获取分类发生了错误:" + e . message )
}
} else {
let p = homeObj . class _parse . split ( ";" ) ;
let p0 = p [ 0 ] ;
let _ps = parseTags . getParse ( p0 ) ;
let is _json = p0 . startsWith ( "json:" ) ;
_pdfa = _ps . pdfa ;
_pdfh = _ps . pdfh ;
_pd = _ps . pd ;
MY _URL = rule . url ;
if ( is _json ) {
try {
let cms _cate _url = homeObj . MY _URL . replace ( "ac=detail" , "ac=list" ) ;
let html = getHtml ( cms _cate _url ) ;
if ( html ) {
if ( cms _cate _url === homeObj . MY _URL ) {
homeHtmlCache = html
}
let list = _pdfa ( html , p0 . replace ( "json:" , "" ) ) ;
if ( list && list . length > 0 ) {
classes = list
}
}
} catch ( e ) {
console . log ( e . message )
}
} else if ( p . length >= 3 && ! is _json ) {
try {
let html = getHtml ( homeObj . MY _URL ) ;
if ( html ) {
homeHtmlCache = html ;
let list = _pdfa ( html , p0 ) ;
if ( list && list . length > 0 ) {
list . forEach ( ( it , idex ) => {
try {
let name = _pdfh ( it , p [ 1 ] ) ;
if ( homeObj . cate _exclude && new RegExp ( homeObj . cate _exclude )
. test ( name ) ) {
return
}
let url = _pd ( it , p [ 2 ] ) ;
if ( p . length > 3 && p [ 3 ] ) {
let exp = new RegExp ( p [ 3 ] ) ;
url = url . match ( exp ) [ 1 ]
}
classes . push ( {
type _id : url . trim ( ) ,
type _name : name . trim ( )
} )
} catch ( e ) {
console . log ( ` 分类列表定位第 ${ idex } 个元素正常报错: ${ e . message } ` )
}
} )
}
}
} catch ( e ) {
console . log ( e . message )
}
}
}
}
classes = classes . filter ( it => ! homeObj . cate _exclude || ! new RegExp ( homeObj . cate _exclude )
. test ( it . type _name ) ) ;
let resp = {
class : classes
} ;
if ( homeObj . filter ) {
resp . filters = homeObj . filter
}
console . log ( JSON . stringify ( resp ) ) ;
return JSON . stringify ( resp )
}
function getPP ( p , pn , pp , ppn ) {
try {
let ps = p [ pn ] === "*" && pp . length > ppn ? pp [ ppn ] : p [ pn ] ;
return ps
} catch ( e ) {
return ""
}
}
function homeVodParse ( homeVodObj ) {
fetch _params = JSON . parse ( JSON . stringify ( rule _fetch _params ) ) ;
let d = [ ] ;
MY _URL = homeVodObj . homeUrl ;
console . log ( MY _URL ) ;
let t1 = ( new Date )
. getTime ( ) ;
let p = homeVodObj . 推荐 ;
print ( "p:" + p ) ;
if ( p === "*" && rule . 一级 ) {
p = rule . 一级 ;
homeVodObj . double = false
}
if ( ! p || typeof p !== "string" ) {
return "{}"
}
p = p . trim ( ) ;
let pp = rule . 一级 . split ( ";" ) ;
if ( p . startsWith ( "js:" ) ) {
const TYPE = "home" ;
var input = MY _URL ;
HOST = rule . host ;
eval ( p . replace ( "js:" , "" ) ) ;
d = VODS
} else {
p = p . split ( ";" ) ;
if ( ! homeVodObj . double && p . length < 5 ) {
return "{}"
} else if ( homeVodObj . double && p . length < 6 ) {
return "{}"
}
let p0 = getPP ( p , 0 , pp , 0 ) ;
let _ps = parseTags . getParse ( p0 ) ;
_pdfa = _ps . pdfa ;
_pdfh = _ps . pdfh ;
_pd = _ps . pd ;
let is _json = p0 . startsWith ( "json:" ) ;
p0 = p0 . replace ( /^(jsp:|json:|jq:)/ , "" ) ;
let html = homeHtmlCache || getHtml ( MY _URL ) ;
homeHtmlCache = undefined ;
if ( is _json ) {
html = dealJson ( html )
}
try {
console . log ( "double:" + homeVodObj . double ) ;
if ( homeVodObj . double ) {
let items = _pdfa ( html , p0 ) ;
let p1 = getPP ( p , 1 , pp , 0 ) ;
let p2 = getPP ( p , 2 , pp , 1 ) ;
let p3 = getPP ( p , 3 , pp , 2 ) ;
let p4 = getPP ( p , 4 , pp , 3 ) ;
let p5 = getPP ( p , 5 , pp , 4 ) ;
let p6 = getPP ( p , 6 , pp , 5 ) ;
for ( let item of items ) {
let items2 = _pdfa ( item , p1 ) ;
for ( let item2 of items2 ) {
try {
let title = _pdfh ( item2 , p2 ) ;
let img = "" ;
try {
img = _pd ( item2 , p3 )
} catch ( e ) { }
let desc = "" ;
try {
desc = _pdfh ( item2 , p4 )
} catch ( e ) { }
let links = [ ] ;
for ( let _p5 of p5 . split ( "+" ) ) {
let link = ! homeVodObj . detailUrl ? _pd ( item2 , _p5 , MY _URL ) : _pdfh ( item2 , _p5 ) ;
links . push ( link )
}
let content ;
if ( p . length > 6 && p [ 6 ] ) {
content = _pdfh ( item2 , p6 )
} else {
content = ""
}
let vid = links . join ( "$" ) ;
if ( rule . 二级 === "*" ) {
vid = vid + "@@" + title + "@@" + img
}
let vod = {
vod _name : title ,
vod _pic : img ,
vod _remarks : desc ,
vod _content : content ,
vod _id : vid
} ;
d . push ( vod )
} catch ( e ) {
console . log ( "首页列表双层定位处理发生错误:" + e . message )
}
}
}
} else {
let items = _pdfa ( html , p0 ) ;
let p1 = getPP ( p , 1 , pp , 1 ) ;
let p2 = getPP ( p , 2 , pp , 2 ) ;
let p3 = getPP ( p , 3 , pp , 3 ) ;
let p4 = getPP ( p , 4 , pp , 4 ) ;
let p5 = getPP ( p , 5 , pp , 5 ) ;
for ( let item of items ) {
try {
let title = _pdfh ( item , p1 ) ;
let img = "" ;
try {
img = _pd ( item , p2 , MY _URL )
} catch ( e ) { }
let desc = "" ;
try {
desc = _pdfh ( item , p3 )
} catch ( e ) { }
let links = [ ] ;
for ( let _p5 of p4 . split ( "+" ) ) {
let link = ! homeVodObj . detailUrl ? _pd ( item , _p5 , MY _URL ) : _pdfh ( item , _p5 ) ;
links . push ( link )
}
let content ;
if ( p . length > 5 && p [ 5 ] ) {
content = _pdfh ( item , p5 )
} else {
content = ""
}
let vid = links . join ( "$" ) ;
if ( rule . 二级 === "*" ) {
vid = vid + "@@" + title + "@@" + img
}
let vod = {
vod _name : title ,
vod _pic : img ,
vod _remarks : desc ,
vod _content : content ,
vod _id : vid
} ;
d . push ( vod )
} catch ( e ) {
console . log ( "首页列表单层定位处理发生错误:" + e . message )
}
}
}
} catch ( e ) { }
}
let t2 = ( new Date )
. getTime ( ) ;
console . log ( "加载首页推荐耗时:" + ( t2 - t1 ) + "毫秒" ) ;
if ( rule . 图片替换 && rule . 图片替换 . includes ( "=>" ) ) {
let replace _from = rule . 图片替换 . split ( "=>" ) [ 0 ] ;
let replace _to = rule . 图片替换 . split ( "=>" ) [ 1 ] ;
d . forEach ( it => {
if ( it . vod _pic && it . vod _pic . startsWith ( "http" ) ) {
it . vod _pic = it . vod _pic . replace ( replace _from , replace _to )
}
} )
}
if ( rule . 图片来源 ) {
d . forEach ( it => {
if ( it . vod _pic && it . vod _pic . startsWith ( "http" ) ) {
it . vod _pic = it . vod _pic + rule . 图片来源
}
} )
}
if ( d . length > 0 ) {
print ( d . slice ( 0 , 2 ) )
}
return JSON . stringify ( {
list : d
} )
}
function categoryParse ( cateObj ) {
fetch _params = JSON . parse ( JSON . stringify ( rule _fetch _params ) ) ;
let p = cateObj . 一级 ;
if ( ! p || typeof p !== "string" ) {
return "{}"
}
let d = [ ] ;
let url = cateObj . url . replaceAll ( "fyclass" , cateObj . tid ) ;
if ( cateObj . pg === 1 && url . includes ( "[" ) && url . includes ( "]" ) ) {
url = url . split ( "[" ) [ 1 ] . split ( "]" ) [ 0 ]
} else if ( cateObj . pg > 1 && url . includes ( "[" ) && url . includes ( "]" ) ) {
url = url . split ( "[" ) [ 0 ]
}
if ( rule . filter _url ) {
if ( ! /fyfilter/ . test ( url ) ) {
if ( ! url . endsWith ( "&" ) && ! rule . filter _url . startsWith ( "&" ) ) {
url += "&"
}
url += rule . filter _url
} else {
url = url . replace ( "fyfilter" , rule . filter _url )
}
2024-05-26 13:39:40 +08:00
url = url . replaceAll ( "fyclass" , cateObj . tid ) ;
2024-05-14 22:28:15 +08:00
let fl = cateObj . filter ? cateObj . extend : { } ;
if ( rule . filter _def && typeof rule . filter _def === "object" ) {
try {
if ( Object . keys ( rule . filter _def )
. length > 0 && rule . filter _def . hasOwnProperty ( cateObj . tid ) ) {
let self _fl _def = rule . filter _def [ cateObj . tid ] ;
if ( self _fl _def && typeof self _fl _def === "object" ) {
let fl _def = JSON . parse ( JSON . stringify ( self _fl _def ) ) ;
fl = Object . assign ( fl _def , fl )
}
}
} catch ( e ) {
print ( "合并不同分类对应的默认筛选出错:" + e . message )
}
}
let new _url ;
new _url = cheerio . jinja2 ( url , {
fl : fl
} ) ;
url = new _url
}
if ( /fypage/ . test ( url ) ) {
if ( url . includes ( "(" ) && url . includes ( ")" ) ) {
let url _rep = url . match ( /.*?\((.*)\)/ ) [ 1 ] ;
let cnt _page = url _rep . replaceAll ( "fypage" , cateObj . pg ) ;
let cnt _pg = eval ( cnt _page ) ;
url = url . replaceAll ( url _rep , cnt _pg )
. replaceAll ( "(" , "" )
. replaceAll ( ")" , "" )
} else {
url = url . replaceAll ( "fypage" , cateObj . pg )
}
}
MY _URL = url ;
console . log ( MY _URL ) ;
p = p . trim ( ) ;
const MY _CATE = cateObj . tid ;
if ( p . startsWith ( "js:" ) ) {
var MY _FL = cateObj . extend ;
const TYPE = "cate" ;
var input = MY _URL ;
const MY _PAGE = cateObj . pg ;
var desc = "" ;
eval ( p . trim ( )
. replace ( "js:" , "" ) ) ;
d = VODS
} else {
p = p . split ( ";" ) ;
if ( p . length < 5 ) {
return "{}"
}
let _ps = parseTags . getParse ( p [ 0 ] ) ;
_pdfa = _ps . pdfa ;
_pdfh = _ps . pdfh ;
_pd = _ps . pd ;
let is _json = p [ 0 ] . startsWith ( "json:" ) ;
p [ 0 ] = p [ 0 ] . replace ( /^(jsp:|json:|jq:)/ , "" ) ;
try {
let html = getHtml ( MY _URL ) ;
if ( html ) {
if ( is _json ) {
html = dealJson ( html )
}
let list = _pdfa ( html , p [ 0 ] ) ;
list . forEach ( it => {
let links = p [ 4 ] . split ( "+" )
. map ( p4 => {
return ! rule . detailUrl ? _pd ( it , p4 , MY _URL ) : _pdfh ( it , p4 )
} ) ;
let link = links . join ( "$" ) ;
let vod _id = rule . detailUrl ? MY _CATE + "$" + link : link ;
let vod _name = _pdfh ( it , p [ 1 ] )
. replace ( /\n|\t/g , "" )
. trim ( ) ;
let vod _pic = _pd ( it , p [ 2 ] , MY _URL ) ;
if ( rule . 二级 === "*" ) {
vod _id = vod _id + "@@" + vod _name + "@@" + vod _pic
}
d . push ( {
vod _id : vod _id ,
vod _name : vod _name ,
vod _pic : vod _pic ,
vod _remarks : _pdfh ( it , p [ 3 ] )
. replace ( /\n|\t/g , "" )
. trim ( )
} )
} )
}
} catch ( e ) {
console . log ( e . message )
}
}
if ( rule . 图片替换 && rule . 图片替换 . includes ( "=>" ) ) {
let replace _from = rule . 图片替换 . split ( "=>" ) [ 0 ] ;
let replace _to = rule . 图片替换 . split ( "=>" ) [ 1 ] ;
d . forEach ( it => {
if ( it . vod _pic && it . vod _pic . startsWith ( "http" ) ) {
it . vod _pic = it . vod _pic . replace ( replace _from , replace _to )
}
} )
}
if ( rule . 图片来源 ) {
d . forEach ( it => {
if ( it . vod _pic && it . vod _pic . startsWith ( "http" ) ) {
it . vod _pic = it . vod _pic + rule . 图片来源
}
} )
}
if ( d . length > 0 ) {
print ( d . slice ( 0 , 2 ) )
}
let pagecount = 0 ;
if ( rule . pagecount && typeof rule . pagecount === "object" && rule . pagecount . hasOwnProperty ( MY _CATE ) ) {
print ( ` MY_CATE: ${ MY _CATE } ,pagecount: ${ JSON . stringify ( rule . pagecount ) } ` ) ;
pagecount = parseInt ( rule . pagecount [ MY _CATE ] )
}
let nodata = {
list : [ {
vod _name : "无数据,防无限请求" ,
vod _id : "no_data" ,
vod _remarks : "不要点,会崩的" ,
vod _pic : "https://ghproxy.net/https://raw.githubusercontent.com/hjdhnx/dr_py/main/404.jpg"
} ] ,
total : 1 ,
pagecount : 1 ,
page : 1 ,
limit : 1
} ;
let vod = d . length < 1 ? JSON . stringify ( nodata ) : JSON . stringify ( {
page : parseInt ( cateObj . pg ) ,
pagecount : pagecount || 999 ,
limit : 20 ,
total : 999 ,
list : d
} ) ;
return vod
}
function searchParse ( searchObj ) {
fetch _params = JSON . parse ( JSON . stringify ( rule _fetch _params ) ) ;
let d = [ ] ;
if ( ! searchObj . searchUrl ) {
return "{}"
}
let p = searchObj . 搜索 === "*" && rule . 一级 ? rule . 一级 : searchObj . 搜索 ;
if ( ! p || typeof p !== "string" ) {
return "{}"
}
p = p . trim ( ) ;
let pp = rule . 一级 . split ( ";" ) ;
let url = searchObj . searchUrl . replaceAll ( "**" , searchObj . wd ) ;
if ( searchObj . pg === 1 && url . includes ( "[" ) && url . includes ( "]" ) && ! url . includes ( "#" ) ) {
url = url . split ( "[" ) [ 1 ] . split ( "]" ) [ 0 ]
} else if ( searchObj . pg > 1 && url . includes ( "[" ) && url . includes ( "]" ) && ! url . includes ( "#" ) ) {
url = url . split ( "[" ) [ 0 ]
}
if ( /fypage/ . test ( url ) ) {
if ( url . includes ( "(" ) && url . includes ( ")" ) ) {
let url _rep = url . match ( /.*?\((.*)\)/ ) [ 1 ] ;
let cnt _page = url _rep . replaceAll ( "fypage" , searchObj . pg ) ;
let cnt _pg = eval ( cnt _page ) ;
url = url . replaceAll ( url _rep , cnt _pg )
. replaceAll ( "(" , "" )
. replaceAll ( ")" , "" )
} else {
url = url . replaceAll ( "fypage" , searchObj . pg )
}
}
MY _URL = url ;
console . log ( MY _URL ) ;
if ( p . startsWith ( "js:" ) ) {
const TYPE = "search" ;
const MY _PAGE = searchObj . pg ;
const KEY = searchObj . wd ;
var input = MY _URL ;
var detailUrl = rule . detailUrl || "" ;
eval ( p . trim ( )
. replace ( "js:" , "" ) ) ;
d = VODS
} else {
p = p . split ( ";" ) ;
if ( p . length < 5 ) {
return "{}"
}
let p0 = getPP ( p , 0 , pp , 0 ) ;
let _ps = parseTags . getParse ( p0 ) ;
_pdfa = _ps . pdfa ;
_pdfh = _ps . pdfh ;
_pd = _ps . pd ;
let is _json = p0 . startsWith ( "json:" ) ;
p0 = p0 . replace ( /^(jsp:|json:|jq:)/ , "" ) ;
try {
let req _method = MY _URL . split ( ";" )
. length > 1 ? MY _URL . split ( ";" ) [ 1 ] . toLowerCase ( ) : "get" ;
let html ;
if ( req _method === "post" ) {
let rurls = MY _URL . split ( ";" ) [ 0 ] . split ( "#" ) ;
let rurl = rurls [ 0 ] ;
let params = rurls . length > 1 ? rurls [ 1 ] : "" ;
print ( ` post=》rurl: ${ rurl } ,params: ${ params } ` ) ;
let _fetch _params = JSON . parse ( JSON . stringify ( rule _fetch _params ) ) ;
let postData = {
body : params
} ;
Object . assign ( _fetch _params , postData ) ;
html = post ( rurl , _fetch _params )
} else if ( req _method === "postjson" ) {
let rurls = MY _URL . split ( ";" ) [ 0 ] . split ( "#" ) ;
let rurl = rurls [ 0 ] ;
let params = rurls . length > 1 ? rurls [ 1 ] : "" ;
print ( ` postjson-》rurl: ${ rurl } ,params: ${ params } ` ) ;
try {
params = JSON . parse ( params )
} catch ( e ) {
params = "{}"
}
let _fetch _params = JSON . parse ( JSON . stringify ( rule _fetch _params ) ) ;
let postData = {
body : params
} ;
Object . assign ( _fetch _params , postData ) ;
html = post ( rurl , _fetch _params )
} else {
html = getHtml ( MY _URL )
}
if ( html ) {
if ( /系统安全验证|输入验证码/ . test ( html ) ) {
let cookie = verifyCode ( MY _URL ) ;
if ( cookie ) {
console . log ( ` 本次成功过验证,cookie: ${ cookie } ` ) ;
setItem ( RULE _CK , cookie )
} else {
console . log ( ` 本次自动过搜索验证失败,cookie: ${ cookie } ` )
}
html = getHtml ( MY _URL )
}
if ( ! html . includes ( searchObj . wd ) ) {
console . log ( "搜索结果源码未包含关键字,疑似搜索失败,正为您打印结果源码" ) ;
console . log ( html )
}
if ( is _json ) {
html = dealJson ( html )
}
let list = _pdfa ( html , p0 ) ;
let p1 = getPP ( p , 1 , pp , 1 ) ;
let p2 = getPP ( p , 2 , pp , 2 ) ;
let p3 = getPP ( p , 3 , pp , 3 ) ;
let p4 = getPP ( p , 4 , pp , 4 ) ;
let p5 = getPP ( p , 5 , pp , 5 ) ;
list . forEach ( it => {
let links = p4 . split ( "+" )
. map ( _p4 => {
return ! rule . detailUrl ? _pd ( it , _p4 , MY _URL ) : _pdfh ( it , _p4 )
} ) ;
let link = links . join ( "$" ) ;
let content ;
if ( p . length > 5 && p [ 5 ] ) {
content = _pdfh ( it , p5 )
} else {
content = ""
}
let vod _id = link ;
let vod _name = _pdfh ( it , p1 )
. replace ( /\n|\t/g , "" )
. trim ( ) ;
let vod _pic = _pd ( it , p2 , MY _URL ) ;
if ( rule . 二级 === "*" ) {
vod _id = vod _id + "@@" + vod _name + "@@" + vod _pic
}
let ob = {
vod _id : vod _id ,
vod _name : vod _name ,
vod _pic : vod _pic ,
vod _remarks : _pdfh ( it , p3 )
. replace ( /\n|\t/g , "" )
. trim ( ) ,
vod _content : content . replace ( /\n|\t/g , "" )
. trim ( )
} ;
d . push ( ob )
} )
}
} catch ( e ) {
print ( "搜索发生错误:" + e . message ) ;
return "{}"
}
}
if ( rule . 图片替换 && rule . 图片替换 . includes ( "=>" ) ) {
let replace _from = rule . 图片替换 . split ( "=>" ) [ 0 ] ;
let replace _to = rule . 图片替换 . split ( "=>" ) [ 1 ] ;
d . forEach ( it => {
if ( it . vod _pic && it . vod _pic . startsWith ( "http" ) ) {
it . vod _pic = it . vod _pic . replace ( replace _from , replace _to )
}
} )
}
if ( rule . 图片来源 ) {
d . forEach ( it => {
if ( it . vod _pic && it . vod _pic . startsWith ( "http" ) ) {
it . vod _pic = it . vod _pic + rule . 图片来源
}
} )
}
return JSON . stringify ( {
page : parseInt ( searchObj . pg ) ,
pagecount : 10 ,
limit : 20 ,
total : 100 ,
list : d
} )
}
function detailParse ( detailObj ) {
let t1 = ( new Date )
. getTime ( ) ;
fetch _params = JSON . parse ( JSON . stringify ( rule _fetch _params ) ) ;
let orId = detailObj . orId ;
let vod _name = "片名" ;
let vod _pic = "" ;
let vod _id = orId ;
if ( rule . 二级 === "*" ) {
let extra = orId . split ( "@@" ) ;
vod _name = extra . length > 1 ? extra [ 1 ] : vod _name ;
vod _pic = extra . length > 2 ? extra [ 2 ] : vod _pic
}
let vod = {
vod _id : vod _id ,
vod _name : vod _name ,
vod _pic : vod _pic ,
type _name : "类型" ,
vod _year : "年份" ,
vod _area : "地区" ,
vod _remarks : "更新信息" ,
vod _actor : "主演" ,
vod _director : "导演" ,
vod _content : "简介"
} ;
let p = detailObj . 二级 ;
let url = detailObj . url ;
let detailUrl = detailObj . detailUrl ;
let fyclass = detailObj . fyclass ;
let tab _exclude = detailObj . tab _exclude ;
let html = detailObj . html || "" ;
MY _URL = url ;
if ( detailObj . 二级访问前 ) {
try {
print ( ` 尝试在二级访问前执行代码: ${ detailObj . 二级访问前 } ` ) ;
eval ( detailObj . 二级访问前 . trim ( )
. replace ( "js:" , "" ) )
} catch ( e ) {
print ( ` 二级访问前执行代码出现错误: ${ e . message } ` )
}
}
if ( p === "*" ) {
vod . vod _play _from = "道长在线" ;
vod . vod _remarks = detailUrl ;
vod . vod _actor = "没有二级,只有一级链接直接嗅探播放" ;
vod . vod _content = MY _URL ;
vod . vod _play _url = "嗅探播放$" + MY _URL . split ( "@@" ) [ 0 ]
} else if ( typeof p === "string" && p . trim ( )
. startsWith ( "js:" ) ) {
const TYPE = "detail" ;
var input = MY _URL ;
var play _url = "" ;
eval ( p . trim ( )
. replace ( "js:" , "" ) ) ;
vod = VOD ;
console . log ( JSON . stringify ( vod ) )
} else if ( p && typeof p === "object" ) {
let tt1 = ( new Date )
. getTime ( ) ;
if ( ! html ) {
html = getHtml ( MY _URL )
}
print ( ` 二级 ${ MY _URL } 仅获取源码耗时: ${ ( new Date ) . getTime ( ) - tt1 } 毫秒 ` ) ;
let _ps ;
if ( p . is _json ) {
print ( "二级是json" ) ;
_ps = parseTags . json ;
html = dealJson ( html )
} else if ( p . is _jsp ) {
print ( "二级是jsp" ) ;
_ps = parseTags . jsp
} else if ( p . is _jq ) {
print ( "二级是jq" ) ;
_ps = parseTags . jq
} else {
print ( "二级默认jq" ) ;
_ps = parseTags . jq
}
let tt2 = ( new Date )
. getTime ( ) ;
print ( ` 二级 ${ MY _URL } 获取并装载源码耗时: ${ tt2 - tt1 } 毫秒 ` ) ;
_pdfa = _ps . pdfa ;
_pdfh = _ps . pdfh ;
_pd = _ps . pd ;
if ( p . title ) {
let p1 = p . title . split ( ";" ) ;
vod . vod _name = _pdfh ( html , p1 [ 0 ] )
. replace ( /\n|\t/g , "" )
. trim ( ) ;
let type _name = p1 . length > 1 ? _pdfh ( html , p1 [ 1 ] )
. replace ( /\n|\t/g , "" )
. replace ( / /g , "" )
. trim ( ) : "" ;
vod . type _name = type _name || vod . type _name
}
if ( p . desc ) {
try {
let p1 = p . desc . split ( ";" ) ;
vod . vod _remarks = _pdfh ( html , p1 [ 0 ] )
. replace ( /\n|\t/g , "" )
. trim ( ) ;
vod . vod _year = p1 . length > 1 ? _pdfh ( html , p1 [ 1 ] )
. replace ( /\n|\t/g , "" )
. trim ( ) : "" ;
vod . vod _area = p1 . length > 2 ? _pdfh ( html , p1 [ 2 ] )
. replace ( /\n|\t/g , "" )
. trim ( ) : "" ;
vod . vod _actor = p1 . length > 3 ? _pdfh ( html , p1 [ 3 ] )
. replace ( /\n|\t/g , "" )
. trim ( ) : "" ;
vod . vod _director = p1 . length > 4 ? _pdfh ( html , p1 [ 4 ] )
. replace ( /\n|\t/g , "" )
. trim ( ) : ""
} catch ( e ) { }
}
if ( p . content ) {
try {
let p1 = p . content . split ( ";" ) ;
vod . vod _content = _pdfh ( html , p1 [ 0 ] )
. replace ( /\n|\t/g , "" )
. trim ( )
} catch ( e ) { }
}
if ( p . img ) {
try {
let p1 = p . img . split ( ";" ) ;
vod . vod _pic = _pd ( html , p1 [ 0 ] , MY _URL )
} catch ( e ) { }
}
let vod _play _from = "$$$" ;
let playFrom = [ ] ;
if ( p . 重定向 && p . 重定向 . startsWith ( "js:" ) ) {
print ( "开始执行重定向代码:" + p . 重定向 ) ;
html = eval ( p . 重定向 . replace ( "js:" , "" ) )
}
if ( p . tabs ) {
if ( p . tabs . startsWith ( "js:" ) ) {
print ( "开始执行tabs代码:" + p . tabs ) ;
var input = MY _URL ;
eval ( p . tabs . replace ( "js:" , "" ) ) ;
playFrom = TABS
} else {
let p _tab = p . tabs . split ( ";" ) [ 0 ] ;
let vHeader = _pdfa ( html , p _tab ) ;
console . log ( vHeader . length ) ;
let tab _text = p . tab _text || "body&&Text" ;
let new _map = { } ;
for ( let v of vHeader ) {
let v _title = _pdfh ( v , tab _text )
. trim ( ) ;
if ( ! v _title ) {
v _title = "线路空"
}
console . log ( v _title ) ;
if ( tab _exclude && new RegExp ( tab _exclude )
. test ( v _title ) ) {
continue
}
if ( ! new _map . hasOwnProperty ( v _title ) ) {
new _map [ v _title ] = 1
} else {
new _map [ v _title ] += 1
}
if ( new _map [ v _title ] > 1 ) {
v _title += Number ( new _map [ v _title ] - 1 )
}
playFrom . push ( v _title )
}
}
console . log ( JSON . stringify ( playFrom ) )
} else {
playFrom = [ "道长在线" ]
}
vod . vod _play _from = playFrom . join ( vod _play _from ) ;
let vod _play _url = "$$$" ;
let vod _tab _list = [ ] ;
if ( p . lists ) {
if ( p . lists . startsWith ( "js:" ) ) {
print ( "开始执行lists代码:" + p . lists ) ;
try {
var input = MY _URL ;
var play _url = "" ;
eval ( p . lists . replace ( "js:" , "" ) ) ;
for ( let i in LISTS ) {
if ( LISTS . hasOwnProperty ( i ) ) {
try {
LISTS [ i ] = LISTS [ i ] . map ( it => it . split ( "$" )
. slice ( 0 , 2 )
. join ( "$" ) )
} catch ( e ) {
print ( "格式化LISTS发生错误:" + e . message )
}
}
}
vod _play _url = LISTS . map ( it => it . join ( "#" ) )
. join ( vod _play _url )
} catch ( e ) {
print ( "js执行lists: 发生错误:" + e . message )
}
} else {
let list _text = p . list _text || "body&&Text" ;
let list _url = p . list _url || "a&&href" ;
let is _tab _js = p . tabs . trim ( )
. startsWith ( "js:" ) ;
for ( let i = 0 ; i < playFrom . length ; i ++ ) {
let tab _name = playFrom [ i ] ;
let tab _ext = p . tabs . split ( ";" )
. length > 1 && ! is _tab _js ? p . tabs . split ( ";" ) [ 1 ] : "" ;
let p1 = p . lists . replaceAll ( "#idv" , tab _name )
. replaceAll ( "#id" , i ) ;
tab _ext = tab _ext . replaceAll ( "#idv" , tab _name )
. replaceAll ( "#id" , i ) ;
let tabName = tab _ext ? _pdfh ( html , tab _ext ) : tab _name ;
console . log ( tabName ) ;
let new _vod _list = [ ] ;
let tt1 = ( new Date )
. getTime ( ) ;
if ( typeof pdfl === "function" ) {
new _vod _list = pdfl ( html , p1 , list _text , list _url , MY _URL )
} else {
let vodList = [ ] ;
try {
vodList = _pdfa ( html , p1 ) ;
console . log ( "len(vodList):" + vodList . length )
} catch ( e ) { }
for ( let i = 0 ; i < vodList . length ; i ++ ) {
let it = vodList [ i ] ;
new _vod _list . push ( _pdfh ( it , list _text )
. trim ( ) + "$" + _pd ( it , list _url , MY _URL ) )
}
}
if ( new _vod _list . length > 0 ) {
new _vod _list = forceOrder ( new _vod _list , "" , x => x . split ( "$" ) [ 0 ] ) ;
console . log ( ` drpy影响性能代码共计列表数循环次数: ${ new _vod _list . length } ,耗时: ${ ( new Date ) . getTime ( ) - tt1 } 毫秒 ` )
}
let vlist = new _vod _list . join ( "#" ) ;
vod _tab _list . push ( vlist )
}
vod _play _url = vod _tab _list . join ( vod _play _url )
}
}
vod . vod _play _url = vod _play _url
}
if ( rule . 图片替换 && rule . 图片替换 . includes ( "=>" ) ) {
let replace _from = rule . 图片替换 . split ( "=>" ) [ 0 ] ;
let replace _to = rule . 图片替换 . split ( "=>" ) [ 1 ] ;
vod . vod _pic = vod . vod _pic . replace ( replace _from , replace _to )
}
if ( rule . 图片来源 && vod . vod _pic && vod . vod _pic . startsWith ( "http" ) ) {
vod . vod _pic = vod . vod _pic + rule . 图片来源
}
if ( ! vod . vod _id || vod _id . includes ( "$" ) && vod . vod _id !== vod _id ) {
vod . vod _id = vod _id
}
let t2 = ( new Date )
. getTime ( ) ;
console . log ( ` 加载二级界面 ${ MY _URL } 耗时: ${ t2 - t1 } 毫秒 ` ) ;
2024-05-26 13:39:40 +08:00
try {
vod = vodDeal ( vod )
} catch ( e ) {
console . log ( ` vodDeal发生错误: ${ e . message } ` )
}
2024-05-14 22:28:15 +08:00
return JSON . stringify ( {
list : [ vod ]
} )
}
function get _tab _index ( vod ) {
let obj = { } ;
vod . vod _play _from . split ( "$$$" )
. forEach ( ( it , index ) => {
obj [ it ] = index
} ) ;
return obj
}
function vodDeal ( vod ) {
let vod _play _from = vod . vod _play _from . split ( "$$$" ) ;
let vod _play _url = vod . vod _play _url . split ( "$$$" ) ;
let tab _removed _list = vod _play _from ;
let tab _ordered _list = vod _play _from ;
let tab _renamed _list = vod _play _from ;
let tab _list = vod _play _from ;
let play _ordered _list = vod _play _url ;
if ( rule . tab _remove && rule . tab _remove . length > 0 || rule . tab _order && rule . tab _order . length > 0 ) {
let tab _index _dict = get _tab _index ( vod ) ;
if ( rule . tab _remove && rule . tab _remove . length > 0 ) {
tab _removed _list = vod _play _from . filter ( it => ! rule . tab _remove . includes ( it ) ) ;
tab _list = tab _removed _list
}
if ( rule . tab _order && rule . tab _order . length > 0 ) {
let tab _order = rule . tab _order ;
tab _ordered _list = tab _removed _list . sort ( ( a , b ) => {
return ( tab _order . indexOf ( a ) === - 1 ? 9999 : tab _order . indexOf ( a ) ) - ( tab _order . indexOf ( b ) === - 1 ? 9999 : tab _order . indexOf ( b ) )
} ) ;
tab _list = tab _ordered _list
}
play _ordered _list = tab _list . map ( it => vod _play _url [ tab _index _dict [ it ] ] )
}
if ( rule . tab _rename && typeof rule . tab _rename === "object" & Object . keys ( rule . tab _rename )
. length > 0 ) {
tab _renamed _list = tab _list . map ( it => rule . tab _rename [ it ] || it ) ;
tab _list = tab _renamed _list
}
vod . vod _play _from = tab _list . join ( "$$$" ) ;
vod . vod _play _url = play _ordered _list . join ( "$$$" ) ;
return vod
}
function tellIsJx ( url ) {
try {
let is _vip = ! /\.(m3u8|mp4|m4a)$/ . test ( url . split ( "?" ) [ 0 ] ) && 是否正版 ( url ) ;
return is _vip ? 1 : 0
} catch ( e ) {
return 1
}
}
function playParse ( playObj ) {
fetch _params = JSON . parse ( JSON . stringify ( rule _fetch _params ) ) ;
MY _URL = playObj . url ;
var MY _FLAG = playObj . flag ;
if ( ! /http/ . test ( MY _URL ) ) {
try {
MY _URL = base64Decode ( MY _URL )
} catch ( e ) { }
}
MY _URL = decodeURIComponent ( MY _URL ) ;
var input = MY _URL ;
var flag = MY _FLAG ;
let common _play = {
parse : 1 ,
url : input ,
flag : flag ,
jx : tellIsJx ( input )
} ;
let lazy _play ;
if ( ! rule . play _parse || ! rule . lazy ) {
lazy _play = common _play
} else if ( rule . play _parse && rule . lazy && typeof rule . lazy === "string" ) {
try {
2024-05-26 13:39:40 +08:00
let lazy _code = rule . lazy . trim ( ) ;
if ( lazy _code . startsWith ( "js:" ) ) {
lazy _code = lazy _code . replace ( "js:" , "" )
. trim ( )
}
2024-05-14 22:28:15 +08:00
print ( "开始执行js免嗅=>" + lazy _code ) ;
eval ( lazy _code ) ;
lazy _play = typeof input === "object" ? input : {
parse : 1 ,
jx : tellIsJx ( input ) ,
url : input
}
} catch ( e ) {
print ( "js免嗅错误:" + e . message ) ;
lazy _play = common _play
}
} else {
lazy _play = common _play
}
if ( Array . isArray ( rule . play _json ) && rule . play _json . length > 0 ) {
let web _url = lazy _play . url ;
for ( let pjson of rule . play _json ) {
if ( pjson . re && ( pjson . re === "*" || web _url . match ( new RegExp ( pjson . re ) ) ) ) {
if ( pjson . json && typeof pjson . json === "object" ) {
let base _json = pjson . json ;
lazy _play = Object . assign ( lazy _play , base _json ) ;
break
}
}
}
} else if ( rule . play _json && ! Array . isArray ( rule . play _json ) ) {
let base _json = {
jx : 1 ,
parse : 1
} ;
lazy _play = Object . assign ( lazy _play , base _json )
} else if ( ! rule . play _json ) {
let base _json = {
jx : 0 ,
parse : 1
} ;
lazy _play = Object . assign ( lazy _play , base _json )
}
console . log ( JSON . stringify ( lazy _play ) ) ;
return JSON . stringify ( lazy _play )
}
function proxyParse ( proxyObj ) {
var input = proxyObj . params ;
if ( proxyObj . proxy _rule ) {
log ( "准备执行本地代理规则:\n" + proxyObj . proxy _rule ) ;
try {
eval ( proxyObj . proxy _rule ) ;
if ( input && input !== proxyObj . params && Array . isArray ( input ) && input . length === 3 ) {
return input
} else {
return [ 404 , "text/plain" , "Not Found" ]
}
} catch ( e ) {
return [ 500 , "text/plain" , "代理规则错误:" + e . message ]
}
} else {
return [ 404 , "text/plain" , "Not Found" ]
}
}
function isVideoParse ( isVideoObj ) {
var input = isVideoObj . url ;
if ( ! isVideoObj . t ) {
let re _matcher = new RegExp ( isVideoObj . isVideo , "i" ) ;
return re _matcher . test ( input )
} else {
try {
eval ( isVideoObj . isVideo ) ;
if ( typeof input === "boolean" ) {
return input
} else {
return false
}
} catch ( e ) {
log ( "执行嗅探规则发生错误:" + e . message ) ;
return false
}
}
}
function init ( ext ) {
console . log ( "init" ) ;
try {
let muban = 模板 . getMubans ( ) ;
if ( typeof ext == "object" ) {
rule = ext
} else if ( typeof ext == "string" ) {
2024-05-26 13:39:40 +08:00
if ( ext . startsWith ( "http" ) || ext . startsWith ( "file://" ) ) {
let query = getQuery ( ext ) ;
2024-05-14 22:28:15 +08:00
let js = request ( ext , {
method : "GET"
} ) ;
if ( js ) {
eval ( js . replace ( "var rule" , "rule" ) )
}
2024-05-26 13:39:40 +08:00
if ( query . type === "url" && query . params ) {
rule . params = urljoin ( ext , query . params )
} else if ( query . params ) {
rule . params = query . params
}
2024-05-14 22:28:15 +08:00
} else {
eval ( ext . replace ( "var rule" , "rule" ) )
}
}
if ( rule . 模板 && muban . hasOwnProperty ( rule . 模板 ) ) {
print ( "继承模板:" + rule . 模板 ) ;
rule = Object . assign ( muban [ rule . 模板 ] , rule )
}
let rule _cate _excludes = ( rule . cate _exclude || "" )
. split ( "|" )
. filter ( it => it . trim ( ) ) ;
let rule _tab _excludes = ( rule . tab _exclude || "" )
. split ( "|" )
. filter ( it => it . trim ( ) ) ;
rule _cate _excludes = rule _cate _excludes . concat ( CATE _EXCLUDE . split ( "|" )
. filter ( it => it . trim ( ) ) ) ;
rule _tab _excludes = rule _tab _excludes . concat ( TAB _EXCLUDE . split ( "|" )
. filter ( it => it . trim ( ) ) ) ;
rule . cate _exclude = rule _cate _excludes . join ( "|" ) ;
rule . tab _exclude = rule _tab _excludes . join ( "|" ) ;
rule . host = ( rule . host || "" )
. rstrip ( "/" ) ;
HOST = rule . host ;
if ( rule . hostJs ) {
console . log ( ` 检测到hostJs,准备执行... ` ) ;
try {
eval ( rule . hostJs ) ;
rule . host = HOST . rstrip ( "/" )
} catch ( e ) {
console . log ( ` 执行 ${ rule . hostJs } 获取host发生错误: ` + e . message )
}
}
rule . url = rule . url || "" ;
rule . double = rule . double || false ;
rule . homeUrl = rule . homeUrl || "" ;
rule . detailUrl = rule . detailUrl || "" ;
rule . searchUrl = rule . searchUrl || "" ;
rule . homeUrl = rule . host && rule . homeUrl ? urljoin ( rule . host , rule . homeUrl ) : rule . homeUrl || rule . host ;
rule . homeUrl = cheerio . jinja2 ( rule . homeUrl , {
rule : rule
} ) ;
rule . detailUrl = rule . host && rule . detailUrl ? urljoin ( rule . host , rule . detailUrl ) : rule . detailUrl ;
rule . 二级访问前 = rule . 二级访问前 || "" ;
if ( rule . url . includes ( "[" ) && rule . url . includes ( "]" ) ) {
let u1 = rule . url . split ( "[" ) [ 0 ] ;
let u2 = rule . url . split ( "[" ) [ 1 ] . split ( "]" ) [ 0 ] ;
rule . url = rule . host && rule . url ? urljoin ( rule . host , u1 ) + "[" + urljoin ( rule . host , u2 ) + "]" : rule . url
} else {
rule . url = rule . host && rule . url ? urljoin ( rule . host , rule . url ) : rule . url
}
if ( rule . searchUrl . includes ( "[" ) && rule . searchUrl . includes ( "]" ) && ! rule . searchUrl . includes ( "#" ) ) {
let u1 = rule . searchUrl . split ( "[" ) [ 0 ] ;
let u2 = rule . searchUrl . split ( "[" ) [ 1 ] . split ( "]" ) [ 0 ] ;
rule . searchUrl = rule . host && rule . searchUrl ? urljoin ( rule . host , u1 ) + "[" + urljoin ( rule . host , u2 ) + "]" : rule . searchUrl
} else {
rule . searchUrl = rule . host && rule . searchUrl ? urljoin ( rule . host , rule . searchUrl ) : rule . searchUrl
}
rule . timeout = rule . timeout || 5e3 ;
rule . encoding = rule . 编码 || rule . encoding || "utf-8" ;
rule . search _encoding = rule . 搜索编码 || rule . search _encoding || "" ;
rule . 图片来源 = rule . 图片来源 || "" ;
rule . 图片替换 = rule . 图片替换 || "" ;
rule . play _json = rule . hasOwnProperty ( "play_json" ) ? rule . play _json : [ ] ;
rule . pagecount = rule . hasOwnProperty ( "pagecount" ) ? rule . pagecount : { } ;
rule . proxy _rule = rule . hasOwnProperty ( "proxy_rule" ) ? rule . proxy _rule : "" ;
2024-05-26 13:39:40 +08:00
if ( ! rule . hasOwnProperty ( "sniffer" ) ) {
rule . sniffer = false
}
2024-05-14 22:28:15 +08:00
rule . sniffer = rule . hasOwnProperty ( "sniffer" ) ? rule . sniffer : "" ;
rule . sniffer = ! ! ( rule . sniffer && rule . sniffer !== "0" && rule . sniffer !== "false" ) ;
rule . isVideo = rule . hasOwnProperty ( "isVideo" ) ? rule . isVideo : "" ;
2024-05-26 13:39:40 +08:00
if ( rule . sniffer && ! rule . isVideo ) {
rule . isVideo = "http((?!http).){12,}?\\.(m3u8|mp4|flv|avi|mkv|rm|wmv|mpg|m4a|mp3)\\?.*|http((?!http).){12,}\\.(m3u8|mp4|flv|avi|mkv|rm|wmv|mpg|m4a|mp3)|http((?!http).)*?video/tos*|http((?!http).)*?obj/tos*"
}
2024-05-14 22:28:15 +08:00
rule . tab _remove = rule . hasOwnProperty ( "tab_remove" ) ? rule . tab _remove : [ ] ;
rule . tab _order = rule . hasOwnProperty ( "tab_order" ) ? rule . tab _order : [ ] ;
rule . tab _rename = rule . hasOwnProperty ( "tab_rename" ) ? rule . tab _rename : { } ;
if ( rule . headers && typeof rule . headers === "object" ) {
try {
let header _keys = Object . keys ( rule . headers ) ;
for ( let k of header _keys ) {
if ( k . toLowerCase ( ) === "user-agent" ) {
let v = rule . headers [ k ] ;
console . log ( v ) ;
if ( [ "MOBILE_UA" , "PC_UA" , "UC_UA" , "IOS_UA" , "UA" ] . includes ( v ) ) {
rule . headers [ k ] = eval ( v )
}
} else if ( k . toLowerCase ( ) === "cookie" ) {
let v = rule . headers [ k ] ;
if ( v && v . startsWith ( "http" ) ) {
console . log ( v ) ;
try {
v = fetch ( v ) ;
console . log ( v ) ;
rule . headers [ k ] = v
} catch ( e ) {
console . log ( ` 从 ${ v } 获取cookie发生错误: ` + e . message )
}
}
}
}
} catch ( e ) {
console . log ( "处理headers发生错误:" + e . message )
}
}
rule _fetch _params = {
headers : rule . headers || false ,
timeout : rule . timeout ,
encoding : rule . encoding
} ;
oheaders = rule . headers || { } ;
RKEY = typeof key !== "undefined" && key ? key : "drpy_" + ( rule . title || rule . host ) ;
pre ( ) ;
init _test ( )
} catch ( e ) {
console . log ( "init_test发生错误:" + e . message )
}
}
let homeHtmlCache = undefined ;
function home ( filter ) {
console . log ( "home" ) ;
2024-05-26 13:39:40 +08:00
if ( typeof rule . filter === "string" && rule . filter . trim ( )
. length > 0 ) {
try {
let filter _json = ungzip ( rule . filter . trim ( ) ) ;
rule . filter = JSON . parse ( filter _json )
} catch ( e ) {
rule . filter = { }
}
}
2024-05-14 22:28:15 +08:00
let homeObj = {
filter : rule . filter || false ,
MY _URL : rule . homeUrl ,
class _name : rule . class _name || "" ,
class _url : rule . class _url || "" ,
class _parse : rule . class _parse || "" ,
cate _exclude : rule . cate _exclude
} ;
return homeParse ( homeObj )
}
function homeVod ( params ) {
console . log ( "homeVod" ) ;
let homeVodObj = {
"推荐" : rule . 推荐 ,
double : rule . double ,
homeUrl : rule . homeUrl ,
detailUrl : rule . detailUrl
} ;
return homeVodParse ( homeVodObj )
}
function category ( tid , pg , filter , extend ) {
let cateObj = {
url : rule . url ,
"一级" : rule . 一级 ,
tid : tid ,
pg : parseInt ( pg ) ,
filter : filter ,
extend : extend
} ;
return categoryParse ( cateObj )
}
function detail ( vod _url ) {
let orId = vod _url ;
let fyclass = "" ;
log ( "orId:" + orId ) ;
if ( vod _url . indexOf ( "$" ) > - 1 ) {
let tmp = vod _url . split ( "$" ) ;
fyclass = tmp [ 0 ] ;
vod _url = tmp [ 1 ]
}
let detailUrl = vod _url . split ( "@@" ) [ 0 ] ;
let url ;
if ( ! detailUrl . startsWith ( "http" ) && ! detailUrl . includes ( "/" ) ) {
url = rule . detailUrl . replaceAll ( "fyid" , detailUrl )
. replaceAll ( "fyclass" , fyclass )
} else if ( detailUrl . includes ( "/" ) ) {
url = urljoin ( rule . homeUrl , detailUrl )
} else {
url = detailUrl
}
let detailObj = {
orId : orId ,
url : url ,
"二级" : rule . 二级 ,
"二级访问前" : rule . 二级访问前 ,
detailUrl : detailUrl ,
fyclass : fyclass ,
tab _exclude : rule . tab _exclude
} ;
return detailParse ( detailObj )
}
function play ( flag , id , flags ) {
let playObj = {
url : id ,
flag : flag ,
flags : flags
} ;
return playParse ( playObj )
}
function search ( wd , quick , pg ) {
if ( rule . search _encoding ) {
if ( rule . search _encoding . toLowerCase ( ) !== "utf-8" ) {
wd = encodeStr ( wd , rule . search _encoding )
}
} else if ( rule . encoding && rule . encoding . toLowerCase ( ) !== "utf-8" ) {
wd = encodeStr ( wd , rule . encoding )
}
let searchObj = {
searchUrl : rule . searchUrl ,
"搜索" : rule . 搜索 ,
wd : wd ,
pg : pg || 1 ,
quick : quick
} ;
return searchParse ( searchObj )
}
function proxy ( params ) {
if ( rule . proxy _rule && rule . proxy _rule . trim ( ) ) {
rule . proxy _rule = rule . proxy _rule . trim ( )
}
if ( rule . proxy _rule . startsWith ( "js:" ) ) {
rule . proxy _rule = rule . proxy _rule . replace ( "js:" , "" )
}
let proxyObj = {
params : params ,
proxy _rule : rule . proxy _rule
} ;
return proxyParse ( proxyObj )
}
function sniffer ( ) {
let enable _sniffer = rule . sniffer || false ;
if ( enable _sniffer ) {
log ( "开始执行辅助嗅探代理规则..." )
}
return enable _sniffer
}
function isVideo ( url ) {
let t = 0 ;
let is _video ;
if ( rule . isVideo && rule . isVideo . trim ( ) ) {
is _video = rule . isVideo . trim ( )
}
if ( is _video . startsWith ( "js:" ) ) {
is _video = is _video . replace ( "js:" , "" ) ;
t = 1
}
let isVideoObj = {
url : url ,
isVideo : is _video ,
t : t
} ;
let result = isVideoParse ( isVideoObj ) ;
if ( result ) {
log ( "成功执行辅助嗅探规则并检测到视频地址:\n" + rule . isVideo )
}
return result
}
function DRPY ( ) {
return {
init : init ,
home : home ,
homeVod : homeVod ,
category : category ,
detail : detail ,
play : play ,
search : search ,
proxy : proxy ,
sniffer : sniffer ,
2024-05-26 13:39:40 +08:00
isVideo : isVideo ,
fixAdM3u8Ai : fixAdM3u8Ai
2024-05-14 22:28:15 +08:00
}
}
export
default {
init : init ,
home : home ,
homeVod : homeVod ,
category : category ,
detail : detail ,
play : play ,
search : search ,
proxy : proxy ,
sniffer : sniffer ,
isVideo : isVideo ,
2024-05-26 13:39:40 +08:00
fixAdM3u8Ai : fixAdM3u8Ai ,
2024-05-14 22:28:15 +08:00
DRPY : DRPY
} ;