xiaomianao666

小程序:福利吧

Jul 9th, 2022
2,346
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
  1. 海阔视界规则分享,当前分享的是:小程序¥home_rule_v2¥base64://@福利吧@{"last_chapter_rule":"","title":"福利吧","author":"","url":"hiker://empty#fyAll#fypage#","version":0,"col_type":"movie_1","class_name":"福利吧&福利&文章推荐&网站推荐&福利汇总","class_url":"&fuli&%e6%8e%a8%e8%8d%90&%e7%bd%91%e7%ab%99%e6%8e%a8%e8%8d%90&flhz","area_name":"下载综合症&游戏推荐&电影推荐&购物网赚&美图摄影","area_url":"xiazaizonghezheng&/tag/游戏推荐&dytj&smzdm&meitusheying","sort_name":"","year_name":"","sort_url":"","year_url":"","find_rule":"js:\n//以下是 列表解析规则（JS）\n\nvar type=MY_URL.split('#')[1];\nvar page=MY_URL.split('#')[2];\n\nvar ul = \"https://fuliba2021.net/\"+type+\"/page/\"+page;\n\nvar status = JSON.parse(fetch(ul, {headers:{\"User-Agent\":MOBILE_UA,\"Referer\":ul}, redirect:false, withHeaders:true}));\nvar res = {};\nvar d = [];\n\nif(status.statusCode!==404){\nvar html=fetch(ul,{});\n\nvar list = parseDomForArray(html, 'body&&article');//       【列表】\n\nfor (var i in list) {\n  let pic = \"https://img0.baidu.com/it/u=1420719556,2509925486&fm=26&fmt=auto&gp=0.jpg\";\n  try{\n      pic = parseDomForHtml(list[i], 'img&&data-src');\n   }catch(e){}\n\td.push({\n\t  title: parseDomForHtml(list[i], 'h2&&Text'),//【标题】\n\t  pic_url: pic, //图片\n\t  desc: \"日期:\"+parseDomForHtml(list[i], '.meta&&time&&Text')+\"  点赞: \"+parseDomForHtml(list[i], '.post-like&&span&&Text'),//【描述】\n\t  url: parseDom(list[i], 'h2&&a&&href') +'#noRecordHistory##noHistory#',//【链接】\n\t});\n}}\nres.data = d;\nsetHomeResult(res);","search_url":"hiker://empty#fypage#**","group":"其它","searchFind":"js:\n//以下是 列表解析规则（JS）\n\nvar page=MY_URL.split('#')[1];\nvar searchn=MY_URL.split('#')[2];\n\nvar ul = \"https://fuliba2021.net/page/\"+ page+\"/?s=\"+searchn;\nvar status = JSON.parse(fetch(ul, {headers:{\"User-Agent\":MOBILE_UA,\"Referer\":ul}, redirect:false, withHeaders:true}));\nvar res = {};\nvar d = [];\n\nif(status.statusCode!==404){\nvar html=fetch(ul,{});\n\nvar list = parseDomForArray(html, 'body&&article');//       【列表】\n\nfor (var i in list) {\n  let pic = \"https://img0.baidu.com/it/u=1420719556,2509925486&fm=26&fmt=auto&gp=0.jpg\";\n  try{\n      pic = parseDomForHtml(list[i], 'img&&data-src');\n   }catch(e){}\n\td.push({\n\t  title: parseDomForHtml(list[i], 'h2&&Text'),//【标题】\n\t  pic_url: pic, //图片\n\t  desc: \"日期:\"+parseDomForHtml(list[i], '.meta&&time&&Text')+\"  点赞: \"+parseDomForHtml(list[i], '.post-like&&span&&Text'),//【描述】\n\t  url: parseDom(list[i], 'h2&&a&&href') +'#noRecordHistory##noHistory#',//【链接】\n\t});\n}}\nres.data = d;\nsetHomeResult(res);","detail_col_type":"rich_text","detail_find_rule":"js:\nvar res={};\nvar d=[];\n\n// 是否隐藏图片，隐藏/1 不隐藏/0\nvar hideImg = 0;\nif(getVar('bfq')=='') putVar('bfq','pic_1_full');\nvar goodColor = \"#4000FF\";\nvar html=getResCode();\n\nfunction getNewText(text,css){\n   return '<'+css+'>' + text + '</'+css+'>';\n}\n\nfunction getBigText(text) {\n    return '<big>' + text + '</big>';\n}\nfunction getSmallText(text) {\n    return '<small>' + text + '</small>';\n}\nfunction getStrongText(text) {\n    return '<strong>' + text + '</strong>';\n}\nfunction getTitleText(text) {\n    return getStrongText(text);\n}\nfunction getColorText(text, color) {\n    return '<font color=\"' + color + '\">' + text + '</font>';\n}\nfunction getGreyText(text) {\n    return getColorText(text, 'grey');\n}\nfunction getAuthorText(text) {\n    return getColorText(text, userColor);\n}\nfunction getCodeText(text) {\n    return '<code>' + text + '</code>';\n}\nfunction getBlockquoteText(text) {\n    return '<blockquote>' + text + '</blockquote>'\n}\nfunction getAddressTag(url, text) {\n    return '<a href=\"' + url + '\">' + text + '</a>'\n}\nfunction getCommentMeta(html) {\n    return getSmallText(html);\n}\n\n//获取重定向地址\nfunction getRedirectAddress(url){\n    let urlRedirect = '';\n    try{\n    \tlet urlCode = fetch(url,{redirect:false,withHeaders:true});\n        urlRedirect = JSON.parse(urlCode).headers.location[0];\n    }catch(e){}\n    return urlRedirect;\n}\n\nString.prototype.replaceWithCallback = function (searchValue, replaceValue, callback) {\n    let returnValue = this;\n    if (callback != null) {\n        returnValue = callback(this, searchValue, replaceValue);\n    }\n    return returnValue;\n};\n\n//删除重定向图片链接\nfunction deleteInvalidImgTag(context, searchValue,replaceValue) {\n    let matchArray = context.match(searchValue);\n    let returnValue = context;\n    if (matchArray != null) {\n        for (let i = 0; i < matchArray.length; i++) {\n            let item = matchArray[i];\n            /<img.*?(data-original|data-src|src)=\"(.*?)\"([\\s\\S]*?)>/.test(item);\n            let imgUrl = RegExp.$2;\n            if (imgUrl.indexOf(\"placeholder\") > -1) {\n                /<img.*?(data-original)=\"(.*?)\"([\\s\\S]*?)>/.test(item);\n                imgUrl = RegExp.$2;\n            }\n            if(imgUrl.indexOf(\"//\")==0){imgUrl = \"https:\" + imgUrl;}\n            if (imgUrl != '') {\n                if(getRedirectAddress(imgUrl) != ''){\n                \treturnValue = returnValue.replace(item,replaceValue);\n                }\n            }\n        }\n    }\n    return returnValue;\n}\n\nfunction imgTagGetUrlArray(context, searchValue) {\n    let matchArray = context.match(searchValue);\n    let returnValue = [];\n    if (matchArray != null) {\n        for (let i = 0; i < matchArray.length; i++) {\n            let item = matchArray[i];\n            /<img.*?(data-original|data-src|src)=\"(.*?)\"([\\s\\S]*?)>/.test(item);\n            let imgUrl = RegExp.$2;\n            if (imgUrl.indexOf(\"placeholder\") > -1) {\n                /<img.*?(data-original)=\"(.*?)\"([\\s\\S]*?)>/.test(item);\n                imgUrl = RegExp.$2;\n            }\n            if(imgUrl.indexOf(\"//\")==0){imgUrl = \"https:\" + imgUrl;}\n            if (imgUrl !== '') {\n                returnValue.push(imgUrl);\n            }\n        }\n    }\n    return returnValue;\n}\n\nlet videoError = '<p><font color=\"grey\">视频暂时无法显示，若要查看请<a href=\"' + MY_URL + '\">访问原文</a></font></p>';\nfunction videoTag(context, videoUrl) {\n    let replaceString = videoUrl === '' ? videoError : '<p><a href=\"' + (videoUrl) + '\">[点击查看视频]</a></p>';\n    if (hideImg) {\n        replaceString = videoUrl === '' ? videoError : '<p><a href=\"' + videoUrl + '\">[点击查看视频]</a></p>';\n    }\n    return context.replace(/<video data-v>/g, replaceString);\n}\nfunction videoTagReplacement2(context, searchValue, replaceValue) {\n    let matchArray = context.match(searchValue);\n    let returnValue = context;\n    if (matchArray != null) {\n        for (let i = 0; i < matchArray.length; i++) {\n            let item = matchArray[i];\n            /<(iframe|source|video).*?(data-original|data-src|src)=\"(.*?)\"([\\s\\S]*?)>/.test(item);\n            let videoUrl = RegExp.$3;\n            if(videoUrl.indexOf(\"//\")==0){videoUrl = \"https:\" + videoUrl;}\n            if(videoUrl.includes(\"zhainanmi\")) continue;\n            if (videoUrl !== '') {\n                returnValue = returnValue.replace(item, replaceValue);\n                returnValue = videoTag(returnValue, videoUrl);\n            }\n        }\n    }\n    return returnValue;\n}\n\n\nfunction getBaiduYunCode(content){\n    if(content.includes(\"pan.baidu.com\")){\n        var code = content.split(\"提取码：\");\n        if(code.length>1) copy(code[1].substring(0,4));\n    }\n}\n\nvar maxPage = 1;\n\ntry {\n    maxPage =  parseInt (parseDomForArray(html,'.article-paging&&a').length+1);\n} catch (e) { }\n\n\nvar goodCount = parseDomForHtml(html, '.action.action-like&&Text');\ngoodCount=getColorText(goodCount,goodColor);\n\nlet headerTitle = getBigText(getStrongText(parseDomForHtml(html, '.article-title&&Text'))) + ' ' + getSmallText(getAddressTag(MY_URL, '[查看原文]'));\n\n//var subTime = getCodeText(parseDomForHtml(html,'.article-meta--a&&li,0&&Text').replace(\"发布于\",\"日期:\"));\n\nvar subType = parseDomForArray(html,'.article-meta&&span,1&&a');\n\nvar type=getCodeText(\"标签: \");\n\nfor(var i=0;i<subType.length;i++){\n    type += getCodeText(parseDomForHtml(subType[i],'a&&Text'));\n}\n\n//if(headerTitle.includes(\"女神\") || headerTitle.includes(\"写真\") || headerTitle.includes(\"套图\") ||type.includes(\"宅男女神\") || type.includes(\"写真套图\")) putVar('bfq','pic_3');\n\nd.push({title: headerTitle+'&nbsp' +goodCount+'<br>'+type,});\nd.push({col_type:'line'});\n\nvar tips = getColorText('温馨提示:图片清晰度较高，加载速度取决于网速！！！','#F47920');\n//if(getVar('bfq')=='pic_3') d.push({title: tips,});\n\nd.push({col_type:\"rich_text\",title:`<small>当前模式为：<a href=\"hiker://empty@lazyRule=.js:putVar('bfq',getVar('bfq')!=='pic_3'?'pic_3':'pic_1_full');refreshPage();'toast://已切换模式';\">`+(getVar('bfq')!=='pic_3'?\"默认大图\":\"小图\")+\"</a></small>\"});\n\nfor (let i = 1; i <= maxPage; i++) {\n    if(i > 1) html = fetch(MY_URL.replace(\".html\", \".html/\" + (i)),{});\n\n    let content = parseDomForHtml(html, '.article-content&&Html');\n\n    content = content\n        .replace(/<br([\\s\\S]*?)>/g, '')\n\t    .replace(/\\n<p>&nbsp;<\\/p>/g,'')\n\t    .replace(/<pre>([\\s\\S]*?)<\\/pre>/g,'')\n\t    .replace(/<img([\\s\\S]*?)!!([\\s\\S]*?)>/g,'');\n\t    //非常耗时和内存\n\t    // .replaceWithCallback(/<img([\\s\\S]*?)>/g, '', deleteInvalidImgTag)\n\t    // .replace(/> /g,'>');\n\n\n    if(maxPage > 1){    \n        content = content.split('\\n<p><span class=\"wp_keywordlink\">')[0];\n    }else{\n    try{\n        let not_copy = parseDomForHtml(content, '.article-update-tips&&Html');\n        content = content.replace(not_copy, '');\n     }catch(e){}\n    }\n\n    getBaiduYunCode(content);\n\n\n    let contentlist = content.split('\\n');\n\n    for(let j=0;j<contentlist.length;j++){\n        let imglist = imgTagGetUrlArray(contentlist[j],/<img([\\s\\S]*?)>/g);\n        let quoteContent = contentlist[j];\n        // var videolist = videoTagGetUrlArray(contentlist[j],/<(iframe|sources|video)([\\s\\S]*?)<\\/(iframe|sources|video)>/g);\n        //文章内容-简单文本\n        quoteContent = quoteContent\n            .replace(/<img([\\s\\S]*?)>/g,'')\n            // .replace(/<(iframe|sources|video)([\\s\\S]*?)<\\/(iframe|sources|video)>/g,'')\n            .replaceWithCallback(/<(iframe|source|video)([\\s\\S]*?)<\\/(iframe|source|video)>/g, \"<video data-v>\", videoTagReplacement2)\n            .replace(/<p><\\/p>/g,'');\n\n        //复杂文本-由Html格式-替换掉图片---视频链接也替换掉用查看视频替代---网站地址不用替换，直接用\n        // quoteContent = getNewText(quoteContent,'div');\n        let temp = parseDomForHtml(getNewText(quoteContent,'div'), 'Text');\n        if(!quoteContent.includes('=\"http')) quoteContent = temp;\n        if(!temp.match(/^\\s*$/)) d.push({title: quoteContent});\n        //漫画模式\n        // var pics=[];\n\t    //for (let k = 0; k < imglist.length; k++){\n\t    //     pics.push(imglist[k]);\n\t    // }\n\t    // \"pics://\"+pics.join(\"&&\");\n\n        if(imglist.length==0) continue;\n        for (let k = 0; k < imglist.length; k++){\n            d.push({\n                pic_url:imglist[k],\n                url:imglist[k],\n                col_type:getVar('bfq')\n            });\n        }\n    }\n}\nres.data=d;\nsetHomeResult(res);","sdetail_col_type":"movie_1","sdetail_find_rule":"*","ua":"mobile","preRule":"","pages":"[]"}
Add Comment
Please, Sign In to add comment