xiaomianao666

小程序:数字图书馆Pro

Oct 16th, 2022
98
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
  1. 海阔视界规则分享,当前分享的是:小程序¥home_rule_v2¥base64://@数字图书馆Pro@{"last_chapter_rule":"","title":"数字图书馆Pro","author":"小棉袄🌞","url":"hiker://empty","version":15,"col_type":"pic_3","class_name":"","type":"news","class_url":"","area_name":"","area_url":"","sort_name":"","year_name":"","sort_url":"","year_url":"","find_rule":"js:\nvar d = [];\nd.push({\n    title: \"搜索\",\n    url: \"'hiker://search?rule=\" + MY_RULE.title + \"&s='+input\",\n    col_type: \"input\",\n    desc: \"\",\n    pic_url: \"\"\n});\nd.push({\n    col_type: \"big_blank_block\"\n});\n\nlet {\n    getDomain\n} = $.require(\"hiker://page/t\");\nlet {\n    domain,\n    host,\n    headers\n} = getDomain();\n\nd.push({\n    title: \"<big>最受欢迎的</big><small>（<a href=\\\"https://\" + host + \"/popular.php\\\">查看原网页</a>）</small>\",\n    col_type: \"rich_text\",\n    extra: {\n        lineVisible: false\n    }\n});\nd.push({\n    title: \"正在加载最受欢迎的书单...\",\n    url: \"\",\n    col_type: \"text_center_1\",\n    desc: \"\",\n    pic_url: \"\",\n    extra: {\n        id: MY_RULE.title\n    }\n});\nd.push({\n    title: \"下载APP\",\n    url: \"web://http://pan.haikuoshijie.cn/%E5%A4%87%E7%94%A8%E4%BB%93%E5%BA%93/%E4%B8%8B%E8%BD%BD%E5%99%A8/Zlib_1.065.apk\",\n    col_type: \"text_2\",\n    desc: \"\",\n    pic_url: \"\"\n});\nd.push({\n    title: \"清除域名\",\n    url: $().lazyRule(() => {\n        clearItem(\"domain\");\n        clearMyVar(\"domain\");\n        refreshPage();\n        return \"hiker://empty\";\n    }),\n    col_type: \"text_2\",\n    desc: \"\",\n    pic_url: \"\"\n});\n\nsetResult(d);\n\nlet u = \"https://\" + domain + \"/popular.php\";\nlet u2 = \"https://\" + host + \"/popular.php\";\nMY_URL = u2;\ntry {\n    let html = request(u, {\n        timeout: 8000,\n        headers: headers\n    });\n    let ht = pdfh(html, \"body&&script,5&&Html\");\n    ht = ht.split(\"ZLibraryModelList(\")[1].split(\").getAll()\")[0]\n    let arr = JSON.parse(ht).books\n    for (let it of arr) {\n        let uid = it.url;\n        addItemBefore(MY_RULE.title, {\n            title: it.title,\n            url: \"hiker://empty##\" + getHome(u2) + uid,\n            col_type: \"text_1\",\n            desc: \"\",\n            pic_url: \"https://covers.zlibcdn2.com\" + it.cover,\n            extra: {\n                id: uid\n            }\n        });\n    }\n} catch (e) {}\ndeleteItem(MY_RULE.title);","search_url":"hiker://empty##**&page=fypage","group":"其它","searchFind":"js:\nvar d = [];\nlet key = MY_URL.split(\"##\")[1];\nlet {\n    getDomain\n} = $.require(\"hiker://page/t\");\nlet {\n    domain,\n    host,\n    headers\n} = getDomain();\n\nlet url = \"https://\" + domain + \"/s/?q=\" + key;\nlet url2 = \"https://\" + host + \"/s/?q=\" + key;\n\n\nlet html = request(url, {\n    headers: headers,\n    timeout: 8000\n});\nlet arr = pdfa(html, \"#searchResultBox&&.resItemBox\");\nfor (let it of arr) {\n    d.push({\n        title: pdfh(it, \"h3&&Text\"),\n        url: \"hiker://empty##\" + getHome(url2) + pdfh(it, \"a&&href\"),\n        col_type: \"\",\n        desc: pdfh(it, \".authors&&Text\"),\n        content: pdfh(it, \".bookDetailsBox&&Text\"),\n        pic_url: pd(it, \"img&&data-src\")\n    });\n}\nsetResult(d);","detail_col_type":"movie_1","detail_find_rule":"js:\nvar d = [];\nlet {\n    getDomain\n} = $.require(\"hiker://page/t\");\nlet {\n    domain,\n    host,\n    headers\n} = getDomain();\nlet u = MY_URL.split(\"##\")[1];\nlet ou = u;\nd.push({\n    title: \"下载地址获取中...\",\n    url: \"toast://地址获取中，请稍候再试\",\n    col_type: \"text_center_1\",\n    desc: \"\",\n    pic_url: \"\",\n    extra: {\n        id: MY_RULE.title + \"@d\"\n    }\n});\n\nd.push({\n    title: \"注意优先点下面网页中的下载，如果两个都无法下载，那就用APP或者特殊网络吧！\",\n    url: \"\",\n    col_type: \"text_1\",\n    desc: \"\",\n    pic_url: \"\",\n    extra: {\n        lineVisible: false\n    }\n});\n\nd.push({\n    title: \"\",\n    url: ou,\n    col_type: \"x5_webview_single\",\n    desc: \"auto\",\n    pic_url: \"\"\n});\n\nsetResult(d);\ntry {\n    u = u.replace(host, domain);\n    let html = request(u, {\n        headers: headers\n    });\n\n    let href = \"https://\" + domain + pdfh(html, \"body&&.details-buttons-container&&a&&href\");\n    let n = pdfh(html, \"body&&.details-buttons-container&&a--i&&Text\");\n    if (n.includes(\"epub\")) {\n        n = n + \".epub\";\n    } else if (n.includes(\"pdf\")) {\n        n = n + \".pdf\";\n    } else if (n.includes(\"txt\")) {\n        n = n + \".txt\";\n    } else if (n.includes(\"mobi\")) {\n        n = n + \".mobi\";\n    }\n    updateItem({\n        title: n,\n        url: \"download://\" + href + \";{Host@\" + host + \"&&Referer@\" + ou + \"}\",\n        col_type: \"text_center_1\",\n        desc: \"\",\n        pic_url: \"\",\n        extra: {\n            id: MY_RULE.title + \"@d\"\n        }\n    });\n} catch (e) {}","sdetail_col_type":"movie_1","sdetail_find_rule":"*","ua":"mobile","preRule":"//手动添加的可用域名\nlet doms = [\n    \"zh.zlib.life\",\n    \"zh.booksc.eu\",\n    \"zh.booksc.xyz\",\n    \"45.178.7.164:443@zh.b-ok.com\",\n    \"81.17.17.254:443@zh.b-ok.com\"\n];\nlet dom = doms[0];\ninitConfig({\n    dom: dom\n});\n\n\n//以下为自动获取可用域名\nvar domains = {\n    'regional': [\"cn1lib.org\", \"2lib.org\", \"b-ok.global\", \"1lib.org\", \"3lib.net\", \"4lib.org\", \"1lib.limited\", \"1lib.education\", \"bookshome.net\", \"libsolutions.net\", \"1lib.net\"],\n    'other': [\"zh.1lib.tw\", \"zh.nl1lib.org\", \"zh.1lib.ae\", \"zh.za1lib.org\", \"zh.vn1lib.org\", \"zh.sg1lib.org\", \"zh.ru1lib.org\", \"zh.pk1lib.org\", \"zh.kr1lib.org\", \"zh.kp1lib.org\", \"zh.au1lib.org\", \"zh.th1lib.org\", \"zh.1lib.nl\", \"zh.pb1lib.org\", \"zh.u1lib.org\", \"zh.usa1lib.org\", \"zh.pt1lib.org\", \"zh.1lib.in\", \"zh.sa1lib.org\", \"zh.tr1lib.org\", \"zh.ua1lib.org\", \"zh.es1lib.org\", \"zh.et1lib.org\", \"zh.gr1lib.org\", \"zh.hu1lib.org\", \"zh.1lib.at\", \"zh.id1lib.org\", \"zh.1lib.cz\", \"zh.by1lib.org\", \"zh.1lib.ph\", \"zh.eg1lib.org\", \"zh.cl1lib.org\", \"zh.ca1lib.org\", \"zh.br1lib.org\", \"zh.be1lib.org\", \"zh.ar1lib.org\", \"zh.jp1lib.org\", \"zh.dk1lib.org\", \"zh.de1lib.org\", \"zh.hk1lib.org\", \"zh.bg1lib.org\", \"zh.1lib.pl\", \"zh.1lib.ch\", \"zh.fr1lib.org\", \"zh.1lib.ma\", \"zh.ng1lib.org\", \"zh.1lib.nz\", \"zh.1lib.mx\", \"zh.it1lib.org\", \"zh.lk1lib.org\", \"zh.ir1lib.org\", \"zh.my1lib.org\", \"zh.ug1lib.org\", \"zh.1lib.sk\", \"zh.sng1lib.org\", \"zh.uk1lib.org\", \"zh.b-ok.cc\", \"zh.1lib.eu\", \"zh.b-ok.lat\", \"zh.b-ok.africa\", \"zh.b-ok.asia\", \"zh.eu1lib.org\", \"zh.b-ok.com\", \"zh.b-ok.org\", \"zh.b-ok2.org\", \"zh.b-ok.xyz\", \"zh.b-ok.as\", \"zh.webbooksnow.org\", \"zh.webbooksnow.club\", \"zh.webbooksnow.how\", \"zh.webbooksnow.art\", \"zh.webbooksnow.net\", \"zh.z-lib.org\", \"zh.bookshome.org\", \"zh.zlibcdn.com\"],\n};\nlet last = getItem(\"domain\", dom);\nlet ok = last != \"no\";\nlog(\"last: \" + last);\nlet {\n    getDomain\n} = $.require(\"hiker://page/t\");\n\nfunction check(d1) {\n    let {\n        domain,\n        host,\n        headers\n    } = getDomain(d1);\n\n    let a = request(\"https://\" + domain + \"/popular.php\", {\n        method: \"HEAD\",\n        timeout: 8000,\n        headers: headers\n    });\n    a = JSON.parse(a);\n    let aa = a.headers != null && a.statusCode != null && (a.statusCode + \"\").startsWith(\"2\") && !a.url.includes(\"expire\");\n    log(domain + \"：\" + aa + \", code: \" + a.statusCode + \", url: \" + a.url);\n    return aa;\n}\nif (ok) {\n    //先校验一下存的域名\n    ok = check(last);\n    if (ok) {\n        putMyVar(\"domain\", last);\n    }\n}\nif (!ok) {\n    //开始批量校验域名\n    let tasks = [];\n    toast(\"获取可用域名中，请稍候\");\n    let ds = doms;\n    try {\n        /*https://zh.1lib.domains/?redirectUrl=&signAll=1&ts=0515\n        let ht = request(\"https://zh.singlelogin.app/\");\n        let a1 = pdfh(ht, \"body&&script&&Html\");\n        let a2 = a1.split(\"const domains = \")[1];\n        */\n\n        let ht = request(\"https://zh.singlelogin.app/\");\n        let a1 = pdfh(ht, \"body&&script,1&&Html\");\n        let a2 = a1.split(\"const booksDomains = \")[1];\n        a2 = a2.split(\"};\")[0] + \"}\";\n        a2 = a2.replace(/'/g, '\"');\n        //log(a2);\n        eval(\"domains = \" + a2);\n        ds = ds.concat(domains.regional.concat(domains.other));\n\n        a2 = a1.split(\"const articlesDomains = \")[1];\n        a2 = a2.split(\"};\")[0] + \"}\";\n        a2 = a2.replace(/'/g, '\"');\n        eval(\"domains = \" + a2);\n        ds = ds.concat(domains.regional.concat(domains.other));\n        log(ds);\n    } catch (e) {\n        log(\"获取域名列表失败：\" + e.toString());\n    }\n\n    function batchnow(tasks) {\n        batchExecute(tasks, {\n            func: function(param, id, error, result) {\n                if (param.domain) {\n                    return \"break\";\n                }\n                if (result) {\n                    param.domain = id;\n                    setItem(\"domain\", id);\n                    putMyVar(\"domain\", id);\n                    log(id);\n                    return \"break\";\n                }\n            },\n            param: {\n                domain: null\n            }\n        })\n    }\n\n    for (let it of ds) {\n        tasks.push({\n            func: function(param) {\n                return check(param.domain)\n            },\n            param: {\n                domain: it\n            },\n            id: it\n        })\n    }\n    batchnow(tasks)\n}","pages":"[{\"col_type\":\"movie_3\",\"name\":\"工具\",\"path\":\"t\",\"rule\":\"function getDomain(domain) {\\n    if (domain == null) {\\n        domain = getMyVar(\\\"domain\\\", config.dom);\\n    }\\n    let hosts = domain.split(\\\"@\\\");\\n    let headers = null;\\n    let host = domain;\\n    if (hosts.length > 1) {\\n        domain = hosts[0];\\n        headers = {\\n            Host: hosts[1]\\n        };\\n        host = hosts[1];\\n    }\\n    return {\\n        domain: domain,\\n        host: host,\\n        headers: headers\\n    }\\n}\\n\\n$.exports = {\\n    getDomain: getDomain\\n}\"}]","icon":""}
Add Comment
Please, Sign In to add comment