123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131 |
- var rule = {
- title: '黑料不打烊[密]',
- host: 'https://hl49.co',
- url: '/category/fyclass/fypage.html',
- searchUrl: '/index/search_article?word=**&page=fypage',
- searchable: 1,
- quickSearch: 0,
- filterable: 0,
- headers: {
- 'User-Agent': 'Mozilla/5.0',
- },
- class_parse: '.slider-content&&a;span&&Text;a&&href;.*/(\\d+)\.html',
- hostJs: $js.toString(() => {
- HOST = 'https://mgj.uzrpy.com';
- try {
- let html = request(rule.host);
- HOST = pdfh(html, ".box-wrap&&a&&href") || HOST;
- } catch (e) {
- log(`获取Host错误${e.message}`);
- }
- }),
- hikerListCol: "card_pic_1",
- hikerClassListCol: "card_pic_1",
- lazy: typeof MY_NAME !== "undefined" ? $js.toString(() => {
- var list = jsp.pdfa(request(input), '.dplayer');
- input = {
- parse: ""
- };
- if (list.length === '1') {
- let url = JSON.parse(pdfh(list[0], '.dplayer&&config')).video.url;
- input.url = url.startsWith("http") ? url : "https://hls.vdtuzv.com" + url;
- } else {
- var a = []
- list.forEach((data, id) => a.push('第' + (id + 1) + '部'))
- input.url = $(a, 1)
- .select(list => {
- input = input.match(/\d+/)[0] - 1
- return $(JSON.parse(pdfh(list[input], '.dplayer&&config'))
- .video.url)
- .lazyRule(() => input.startsWith("http") ? input : "https://hls.vdtuzv.com" + input)
- }, list)
- }
- }) : void 0,
- play_parse: true,
- limit: 6,
- proxy_rule: $js.toString(() => {
- //log(input);
- // 测试:https://www.wakatool.com/base64img
- if (input) {
- let t1 = new Date().getTime();
- let _type = input.url.split('.').slice(-1)[0];
- let data = request(input.url, {toBase64: true});
- //log(data);
- let t2 = new Date().getTime();
- log(`网络请求获取图片耗时:${t2 - t1}ms`);
- // log(`当前线程:${java.lang.Thread.currentThread().getName()}`);
- let key = CryptoJS.enc.Utf8.parse("f5d965df75336270");
- let iv = CryptoJS.enc.Utf8.parse("97b60394abc2fbe1");
- let encrypted = CryptoJS.AES.decrypt({
- ciphertext: CryptoJS.enc.Base64.parse(data)
- }, key, {
- iv: iv,
- mode: CryptoJS.mode.CBC,
- padding: CryptoJS.pad.Pkcs7
- }).toString(CryptoJS.enc.Base64);
- // .toString(CryptoJS.enc.Utf8).toTypedArray(CryptoJS.enc.Utf8); //直接转参数3可用的字节流方法
- let img_base64 = 'data:image/' + _type + ';base64,' + encrypted;
- let t3 = new Date().getTime();
- log(`已获取图片${input.url}解密耗时:${t3 - t2}ms`);
- // // input = [200, 'text/plain', img_base64];
- // input = [302, 'text/html', '', {Location:'https://www.baidu.com'}];
- input = [200, 'image/' + _type, img_base64, null, 1];
- // input = [200, 'text/plain', data];
- }
- }),
- 预处理: $js.toString(() => {
- rule.cate_exclude = '';
- }),
- 推荐: '*',
- 一级: $js.toString(() => {
- let d = [];
- let html = request(input);
- let list = pdfa(html, '.video-item');
- list.forEach(item => {
- var pic = pdfh(item, 'img&&onload');
- var url = pd(item, 'a&&href', MY_URL);
- var title = pdfh(item, '.title&&Text');
- if (title) {
- d.push({
- title: title,
- img: pic,
- desc: "0",
- url: url
- });
- }
- });
- setResult(d);
- }),
- //一级: '.video-item;.title&&Text;img&&onload;;a&&href',
- 图片替换: $js.toString(() => {
- if (/loadImg/.test(input)) {
- input = input.split("'")[1];
- }
- // tim壳子专用图片解密
- // input = input + '@Option:{"mode":"CBC","inbase64":false,"key":"f5d965df75336270","iv":"97b60394abc2fbe1"}';
- input = getProxyUrl() + '&url=' + input;
- }),
- 二级: "*",
- 搜索: $js.toString(() => {
- let d = [];
- let u = input.split("?");
- let h = post(u[0], {
- body: u[1]
- });
- let list = JSON.parse(h).data.list;
- list.forEach(item => {
- let pic = item.thumb;
- let url = `${rule.host}/archives/${item.id}.html`
- d.push({
- title: item.title,
- desc: item.created_date,
- img: pic,
- url: url
- });
- });
- setResult(d);
- })
- }
|