Parcourir la source

改了个版本,待处理问题

hjdhnx il y a 2 mois
Parent
commit
c94e89405f
1 fichiers modifiés avec 39 ajouts et 2 suppressions
  1. 39 2
      app/t4/files/drpy_js/采集之王[合].js

+ 39 - 2
app/t4/files/drpy_js/采集之王[合].js

@@ -18,10 +18,11 @@ globalThis.getRandomItem = function (items) {//从列表随机取出一个元素
 var rule = {
     title: '采集之王[合]',
     author: '道长',
-    version: '20240705 beta12',
+    version: '20240705 beta13',
     update_info: `
 20240705:
 1.支持传参json后面增加#1 这样的额外标识,用于搜索结果精准匹配
+2.支持传参json后面增加#1#1 这样的额外标识,用于强制获取搜索图片。#1#不显示图片。默认是搜索强制有图片的[待实现详情页请求使用批量]
 20240703:
 1.采集json支持"searchable": 0,用于搜索时排除这个源
 20240604:
@@ -50,8 +51,9 @@ var rule = {
     play_parse: true,
     parse_url: '', // 这个参数暂时不起作用。聚合类的每个资源应该有自己独立的解析口。单独配置在采集.json里的parse_url有效
     search_match: false, // 搜索精准匹配
+    search_pic: true, // 搜索强制需要图片
     // params: 'http://127.0.0.1:5707/files/json/%E9%87%87%E9%9B%86.json',
-    // params: 'http://127.0.0.1:5707/files/json/采集静态.json',
+    // params: 'http://127.0.0.1:5707/files/json/采集静态.json#1',
     // params: 'http://127.0.0.1:5707/files/json/采集[zy]静态.json#1',
     // hostJs:$js.toString(()=>{
     //
@@ -92,6 +94,9 @@ var rule = {
                 let _url_params = _url.split('#');
                 _url = _url_params[0];
                 rule.search_match = !!(_url_params[1]);
+                if (_url_params.length > 2) { // 强制图片
+                    rule.search_pic = !!(_url_params[2]);
+                }
             }
             let html = request(_url);
             let json = JSON.parse(html);
@@ -301,6 +306,22 @@ var rule = {
                                         data = data.filter(item => item.vod_name && (new RegExp(KEY, 'i')).test(item.vod_name))
                                     }
                                     if (data.length > 0) {
+                                        if (rule.search_pic && !data[0].vod_pic) {
+                                            log(`当前搜索站点【${it.type_name}】没图片,尝试访问二级去获取图片`);
+                                            let detailUrl = urls[idx].split('wd=')[0] + 'ac=detail&ids=' + data.map(k => k.vod_id.split('$')[1]).join(',');
+                                            try {
+                                                let detailJson = JSON.parse(request(detailUrl));
+                                                data.forEach((d, _seq) => {
+                                                    log('二级数据列表元素数:' + detailJson.list.length);
+                                                    let detailVodPic = detailJson.list[_seq].vod_pic;
+                                                    if (detailVodPic) {
+                                                        Object.assign(d, {vod_pic: detailVodPic});
+                                                    }
+                                                });
+                                            } catch (e) {
+                                                log(`强制获取网站${it.type_id}的搜索图片失败:${e.message}`);
+                                            }
+                                        }
                                         results = results.concat(data);
                                     }
                                 } catch (e) {
@@ -323,6 +344,22 @@ var rule = {
                                     data = data.filter(item => item.vod_name && (new RegExp(KEY, 'i')).test(item.vod_name))
                                 }
                                 if (data.length > 0) {
+                                    if (rule.search_pic && !data[0].vod_pic) {
+                                        log(`当前搜索站点【${it.type_name}】没图片,尝试访问二级去获取图片`);
+                                        let detailUrl = urls[idx].split('wd=')[0] + 'ac=detail&ids=' + data.map(k => k.vod_id.split('$')[1]).join(',');
+                                        try {
+                                            let detailJson = JSON.parse(request(detailUrl));
+                                            data.forEach((d, _seq) => {
+                                                log('二级数据列表元素数:' + detailJson.list.length);
+                                                let detailVodPic = detailJson.list[_seq].vod_pic;
+                                                if (detailVodPic) {
+                                                    Object.assign(d, {vod_pic: detailVodPic});
+                                                }
+                                            });
+                                        } catch (e) {
+                                            log(`强制获取网站${it.type_id}的搜索图片失败:${e.message}`);
+                                        }
+                                    }
                                     results = results.concat(data);
                                 }
                                 results = results.concat(data);