猫眼看书
http://api.jmlldsc.com
autobcb_admin (12020)3天前
猫眼看书 作者 清词
{
"bookSourceUrl": "http:\/\/api.jmlldsc.com",
"bookSourceName": "猫眼看书",
"enabledExplore": true,
"enabled": true,
"bookSourceGroup": "",
"author": "清词",
"help": true,
"html": "<!DOCTYPE html>\n<html lang=\"en\">\n<head>\n <meta charset=\"UTF-8\">\n <title>猫眼看书<\/title>\n<\/head>\n<body>\n\n<\/body>\n<!-- 没用到jq请去掉-->\n<script src=\"https:\/\/vc.jd.com\/web\/js\/jquery-3.1.1.min.js\"><\/script>\n<script src=\"https:\/\/cdn.bootcdn.net\/ajax\/libs\/crypto-js\/4.1.1\/crypto-js.min.js\"><\/script>\n<script>\n var isCookieJar=true;\/\/ 不需要CookieJar请修改此处\n class FlutterJSBridge {\n constructor() {\n this.init(); \/\/前台webview 里必须删除这行\n }\n\n init() {\n if (window.flutter_inappwebview) {\n this.isReady = true;\n this.CookieJar();\n } else {\n window.addEventListener('flutterInAppWebViewPlatformReady', () => {\n this.isReady = true;\n console.log('JSBridge初始化完成');\n this.CookieJar();\n });\n }\n }\n\n \/\/通知原生页面初始化完成,仅在书源和tts生效,webview请勿使用,只有通知加载成功后才允许运行,否则会一直等待加载成功\n async CookieJar() {\n try {\n await window.flutter_inappwebview.callHandler('CookieJar', isCookieJar);\n } catch (error) {\n console.error('汇报完成准备失败:', error);\n }\n }\n\n \/\/获取应用编译版本\n async getbuildNumber() {\n try {\n return await window.flutter_inappwebview.callHandler('buildNumber');\n } catch (error) {\n return 0;\n }\n }\n\n \/\/获取应用版本\n async getversion() {\n try {\n return await window.flutter_inappwebview.callHandler('version');\n } catch (error) {\n return \"0.0.0\";\n }\n }\n \n \/\/将简体字转成繁体字\n async toTraditional(str) {\n try {\n return await window.flutter_inappwebview.callHandler('toTraditional',str);\n } catch (error) {\n return \"\";\n }\n }\n \n \n \/\/将繁体字转成简体字\n async toSimplified(str) {\n try {\n return await window.flutter_inappwebview.callHandler('toSimplified',str);\n } catch (error) {\n return \"\";\n }\n }\n\n \/\/播放朗读引擎仅tts源生效\n async voice() {\n try {\n return await window.flutter_inappwebview.callHandler('voice');\n } catch (error) {\n return \"\";\n }\n }\n \n\n \/\/获取设备唯一id\n async getDeviceid() {\n try {\n return await window.flutter_inappwebview.callHandler('id');\n } catch (error) {\n return \"\";\n }\n }\n\n \/\/获取设备平台 此处返回 windows、macos、ios、ohos、android\n async getDevice() {\n try {\n return await window.flutter_inappwebview.callHandler('device');\n } catch (error) {\n return \"\";\n }\n }\n\n \/\/输出日志,前台webview请勿使用\n \/\/str 为 String\n async log(str) {\n try {\n return await window.flutter_inappwebview.callHandler('log',str);\n } catch (error) {\n return false;\n }\n }\n\n \/\/书源调试时可输出 html 代码到前台\n \/\/type 0 搜索源码 , 1详情源码 ,2目录源码 ,3正文源码\n \/\/str 为 String\n \/\/type 为int\n async text(type,str) {\n try {\n return await window.flutter_inappwebview.callHandler('text',type,str);\n } catch (error) {\n return false;\n }\n }\n\n \/\/toast弹窗\n \/\/str 为 String\n async showToast(str) {\n try {\n return await window.flutter_inappwebview.callHandler('showToast',str);\n } catch (error) {\n return false;\n }\n }\n\n \/\/webview 里禁止使用,webview请使用js获取ua (navigator.userAgent)\n \/\/获取默认ua\n async getWebViewUA() {\n try {\n return await window.flutter_inappwebview.callHandler('getWebViewUA');\n } catch (error) {\n return \"\";\n }\n }\n\n \/\/通过url打开外部应用\n \/\/url 为 String\n async openurl(url) {\n try {\n return await window.flutter_inappwebview.callHandler('openurl',url,\"\");\n } catch (error) {\n return false;\n }\n }\n\n \/\/通过url打开外部应用并附带mimeType\n \/\/url 为 String\n \/\/mimeType 为 String\n async openurlwithMimeType(url,mimeType) {\n try {\n return await window.flutter_inappwebview.callHandler('openurl',url,mimeType);\n } catch (error) {\n return false;\n }\n }\n\n \/**\n * 使用webView访问网络\n * @param html 直接用webView载入的html, 如果html为空直接访问url\n * @param url html内如果有相对路径的资源不传入url访问不了\n * @param js 用来取返回值的js语句, 没有就返回整个源代码\n * @param body 当参数不为空的时候,会以post请求,此时请务必在 header 中带上content-type\n * @param header 请求的header头,此参数必须是json字符串\n * @return 返回js获取的内容\n *\/\n async webview(url,js,html,body,header) {\n try {\n return await window.flutter_inappwebview.callHandler('webview',url,js,html,body,header,\"\",\"\");\n } catch (error) {\n return \"\";\n }\n }\n\n \/**\n * overrideUrlRegex 为正则表达式\n * 使用方法和上面的一样\n * 但返回的内容为正则到的内容,如果无法正则到则返回 js 获取的内容,如果 js 为空则返回页面 html\n *\/\n async webViewGetOverrideUrl(url,js,html,body,header,overrideUrlRegex) {\n try {\n return await window.flutter_inappwebview.callHandler('webview',url,js,html,body,header,overrideUrlRegex,\"\");\n } catch (error) {\n return \"\";\n }\n }\n\n \/**\n * 使用webView获取资源url\n * urlregex 为正则表达式\n * 使用方法和上面的一样\n * 但返回的内容为正则到的内容,如果无法正则到则返回 js 获取的内容,如果 js 为空则返回页面 html\n *\/\n async webViewGetSource(url,js,html,body,header,urlregex) {\n try {\n return await window.flutter_inappwebview.callHandler('webview',url,js,html,body,header,\"\",urlregex);\n } catch (error) {\n return \"\";\n }\n }\n \n \/**\n * 使用webView拦截 ajax\n * ajaxregex 为正则表达式,通过 ajax 匹配 path\n * 匹配成功返回 ajax 的结果 失败返回 html\n *\/\n async webViewGetAjax(url,html,body,header,ajaxregex) {\n try {\n return await window.flutter_inappwebview.callHandler('webviewajax',url,html,body,header,ajaxregex);\n } catch (error) {\n return \"\";\n }\n }\n\n\n\n \/**\n * 启动前台 webview 访问链接并获取结束时的 html,可用于手工过盾\n * @param url 网址\n * @param title 标题\n * @param header 请求的header头,此参数必须是json字符串\n * @return 返回网页的内容\n *\/\n async startBrowser(url,title,header) {\n try {\n return await window.flutter_inappwebview.callHandler('startBrowser',url,title,header);\n } catch (error) {\n return \"\";\n }\n }\n \n \/**\n * 启动前台 webview 并对每次打开的 url 进行拦截\n * @param url 网址\n * @param title 标题\n * @param header 请求的header头,此参数必须是json字符串\n *\/\n async startBrowserWithShouldOverrideUrlLoading(url,title,header) {\n try {\n return await window.flutter_inappwebview.callHandler('startBrowserWithShouldOverrideUrlLoading',url,title,header);\n } catch (error) {\n return \"\";\n }\n }\n\n \/\/专门为段评设置的半屏显示,不返回任何东西\n async startBrowserDp(url,title) {\n try {\n return await window.flutter_inappwebview.callHandler('startBrowserDp',url,title);\n } catch (error) {\n return \"\";\n }\n }\n\n \/\/仅前台webview可以使用,返回按钮,返回上一个页面\n async back() {\n try {\n return await window.flutter_inappwebview.callHandler('back');\n } catch (error) {\n return false;\n }\n }\n\n \/\/将 utf8字符串转到 gbk 并 url 编码\n async utf8ToGbkUrlEncoded(str) {\n try {\n return await window.flutter_inappwebview.callHandler('utf8ToGbkUrlEncoded',str);\n } catch (error) {\n return \"\";\n }\n }\n\n \/*\n * @param str为图片链接 \n * @param header 请求的header头,此参数必须是json字符串\n * 此函数是让用户输入图片中的验证码,当链接为空则直接让用户输入验证码\n *\/\n async getVerificationCode(str,header) {\n try {\n return await window.flutter_inappwebview.callHandler('getVerificationCode',str,header);\n } catch (error) {\n return \"\";\n }\n }\n \n \/\/提交内容bookUrl,我会调用书源 info 函数来获取这本书的信息\n async addbook(bookUrl) {\n try {\n return await window.flutter_inappwebview.callHandler('addbook',bookUrl);\n } catch (error) {\n return \"\";\n }\n }\n \n \n \/\/获取书本当前阅读章节index\n async getdurChapterIndex(bookUrl) {\n try {\n return await window.flutter_inappwebview.callHandler('getdurChapterIndex',bookUrl);\n } catch (error) {\n return 0;\n }\n }\n \n \/\/utf8 字符串转base64\n async base64encode(str) {\n try {\n return await window.flutter_inappwebview.callHandler('base64encode',str);\n } catch (error) {\n return \"\";\n }\n }\n \n \/\/base64 转utf8字符串\n async base64decode(str) {\n try {\n return await window.flutter_inappwebview.callHandler('base64decode',str);\n } catch (error) {\n return \"\";\n }\n }\n \n \n\n }\n\n \/\/webview下isCookieJar必定true 会自动处理cookie\n \/\/以下提交的url,headers,body 都必须为字符串,headers必须为json字符串\n \/\/当followRedirects 为 false 时不处理重定向,当为 true 时会自动处理重定向 ,如不明白用途直接用 true 最佳\n \/\/ 以下所有参数除当followRedirects外均为 String\n \/\/ 如果需要使用http2协议 请在url 前添加 http2:\/\/ ,例如 http2:\/\/baidu.com\n \/\/ 如果https一直被盾拦截 ,可以使用https2协议\n class Http {\n constructor() {}\n\n \/*\n * 通用返回字段\n * method post get 或者 head\n * body 请求返回后的字节的 base64\n * headers map<String,List<String>> 可通过headers[\"\"]来或者\n * statusCode 状态码\n * statusMessage \n * data 返回后的字节 格式化后的内容 \n *\/\n async Get(url,headers,followRedirects) {\n try {\n return await window.flutter_inappwebview.callHandler('http',\"get\",url,\"\",JSON.stringify(headers),followRedirects,\"\");\n } catch (error) {\n return null;\n }\n }\n\n async Head(url,headers,followRedirects) {\n try {\n return await window.flutter_inappwebview.callHandler('http',\"head\",url,\"\",JSON.stringify(headers),followRedirects,\"\");\n } catch (error) {\n return null;\n }\n }\n\n \n async Post(url,headers,body,contenttype,followRedirects) {\n try {\n return await window.flutter_inappwebview.callHandler('http',\"post\",url,body,JSON.stringify(headers),followRedirects,contenttype);\n } catch (error) {\n return null;\n }\n }\n }\n\n class Cache {\n constructor() {}\n async get(key) {\n try {\n return await window.flutter_inappwebview.callHandler('cache.get',key);\n } catch (error) {\n return null;\n }\n }\n\n async set(key,value) {\n try {\n return await window.flutter_inappwebview.callHandler('cache.set',key,value);\n } catch (error) {\n return null;\n }\n }\n\n async remove(key) {\n try {\n return await window.flutter_inappwebview.callHandler('cache.remove',key);\n } catch (error) {\n return null;\n }\n }\n\n \/\/如果登录为弹窗格式的,里面输入框输入的内容可以通过这个函数获取,默认返回的json格式或者为空,需要自行转换\n async getLoginInfo(){\n return await this.get(\"LoginInfo\")\n }\n\n \/\/将修改后的弹窗输入内容报错 ,必须 JSON.stringify,不然会出错\n async putLoginInfo(info){\n return await this.set(\"LoginInfo\",info)\n }\n \n \/\/获取书本变量 \n async getbookVariable(bookurl){\n return await this.get(bookurl)\n }\n \n \/\/写入书本变量 \n async setbookVariable(bookurl,value){\n return await this.set(bookurl,value)\n }\n }\n\n class Cookie {\n constructor() {}\n\n \/\/通过url获取当前url的所有cookie\n async get(url) {\n try {\n return await window.flutter_inappwebview.callHandler('cookie.get',url);\n } catch (error) {\n return null;\n }\n }\n\n \/\/通过url删除当前url的所有cookie\n async remove(url) {\n try {\n return await window.flutter_inappwebview.callHandler('cookie.remove',url);\n } catch (error) {\n return null;\n }\n }\n\n\n \/\/通过url保存当前url的所有cookie\n async set(url,value) {\n try {\n return await window.flutter_inappwebview.callHandler('cookie.set',url,value);\n } catch (error) {\n return null;\n }\n }\n \n \/\/设置单独一个cookie\n async setCookie(url,key,value) {\n try {\n return await window.flutter_inappwebview.callHandler('cookie.setcookie',url,key,value);\n } catch (error) {\n return null;\n }\n }\n\n \/\/通过 url 获取单个 cookie 的值\n async getCookie(url,value) {\n try {\n return await window.flutter_inappwebview.callHandler('cookie.getCookie',url,value);\n } catch (error) {\n return null;\n }\n }\n }\n\n \/\/安全的创建一个 div 解析 html\n function parseHTMLSafely(htmlStr) {\n try {\n \/\/ 在函数作用域内创建独立的临时容器\n \/\/ 每个调用创建新的jQuery对象,互不影响\n var tempDiv = document.createElement('div');\n tempDiv.innerHTML = htmlStr;\n return $(tempDiv);\n } catch (e) {\n flutterBridge.log(\"HTML解析错误:\"+e.message);\n return $('<div>');\n }\n }\n\n \/\/parseHTMLSafely 创建的用完后必须删除\n function removeHTMLSafely(tempContainer) {\n try {\n tempContainer.innerHTML = '';\n if (tempContainer.parentNode) {\n tempContainer.parentNode.removeChild(tempContainer);\n }\n } catch (e) {\n flutterBridge.log(\"HTML移除失败:\"+e.message);\n }\n }\n\n \/\/移除 css js,创建parseHTMLSafely前如果用不上 cssjs 建议移除\n function removeHTMLTags(htmlString) {\n \/\/ 移除script标签\n let result = htmlString.replace(\/<script\\b[^<]*(?:(?!<\\\/script>)<[^<]*)*<\\\/script>\/gi, '');\n \/\/ 移除style标签\n result = result.replace(\/<style\\b[^<]*(?:(?!<\\\/style>)<[^<]*)*<\\\/style>\/gi, '');\n return result;\n }\n\n<\/script>\n\n<script>\n const flutterBridge = new FlutterJSBridge();\n const cache = new Cache();\n const http = new Http();\n const cookie = new Cookie();\n \n var baseurl1 = \"http:\/\/api.lemiyigou.com\";\n var baseurl2 = \"http:\/\/api.jmlldsc.com\";\n var currentBaseUrl = baseurl1; \/\/ 默认使用第一个域名\n\n var headers = {\n \"User-Agent\": \"okhttp\/4.9.2\",\n \"client-device\": \"0cdeb38dd0f2a381b06c0a02926ee317\",\n \"client-brand\": \"vivo\",\n \"client-version\": \"2.3.0\",\n \"client-name\": \"app.maoyankanshu.novel\",\n \"client-source\": \"android\",\n \"Authorization\": \"bearereyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJpc3MiOiJodHRwOlwvXC9hcGkuam1sbGRzYy5jb21cL2F1dGhcL3RoaXJkIiwiaWF0IjoxNzIzNzI2NTkyLCJleHAiOjE4MTcwMzg1OTIsIm5iZiI6MTcyMzcyNjU5MiwianRpIjoiMHJaS05IdlRVelR4Vm15SCIsInN1YiI6ODAyMzcyLCJwcnYiOiJhMWNiMDM3MTgwMjk2YzZhMTkzOGVmMzBiNDM3OTQ2NzJkZDAxNmM1In0.w9vCdsWWqnD5pTz5aluSDb8WxeLZqrZsqX06CYC_J1A\",\n \"Accept\": \"application\/json\",\n \"Content-Type\": \"application\/json\"\n };\n\n function aesDecrypt(encryptedBase64) {\n try {\n const key = CryptoJS.enc.Utf8.parse(\"f041c49714d39908\");\n const iv = CryptoJS.enc.Utf8.parse(\"0123456789abcdef\");\n\n const encryptedData = CryptoJS.enc.Base64.parse(encryptedBase64);\n \n const decrypted = CryptoJS.AES.decrypt(\n { ciphertext: encryptedData },\n key,\n {\n iv: iv,\n mode: CryptoJS.mode.CBC,\n padding: CryptoJS.pad.Pkcs7\n }\n );\n \n \/\/ 转换为UTF-8字符串\n return decrypted.toString(CryptoJS.enc.Utf8);\n } catch (error) {\n flutterBridge.log(\"AES解密错误: \" + error.message);\n return \"\";\n }\n }\n\n function cleanChapterName(chapterName) {\n if (!chapterName) return \"\";\n return chapterName\n .replace(\/正文卷\\.|正文\\.|VIP卷\\.|默认卷\\.|卷_|VIP章节\\.|免费章节\\.|章节目录\\.|最新章节\\.\/g, \"\")\n .replace(\/[\\\\((【].*?[求更票谢乐发订合补加架字修Kk].*?[】)\\\\)]\/g, \"\")\n .trim();\n }\n\n function cleanIntro(intro) {\n if (!intro) return \"\";\n \/\/ 在句号和感叹号后面添加换行\n return intro.replace(\/([。!?]+[”」)】]?)\/g, \"$1<br>\");\n }\n\n function cleanContent(content) {\n if (!content) return \"\";\n return content\n .replace(\/一秒记住.*精彩阅读。|7017k|看无广告.*| var.*;|【.*\\\/\\\/\/g, \"\")\n .replace(\/\\n\\s*\\n\/g, '\\n\\n')\n .trim();\n }\n\n async function search(key, page) {\n try {\n const pageNum = page || 1;\n const url = `${currentBaseUrl}\/search?page=${pageNum}&keyword=${encodeURIComponent(key)}`;\n \n const response = await http.Get(url, JSON.stringify(headers), true);\n \n if (!response || !response.data) {\n return \"[]\";\n }\n\n flutterBridge.text(0, response.data);\n \n try {\n const data = JSON.parse(response.data);\n if (!data || !data.data || !Array.isArray(data.data)) {\n return \"[]\";\n }\n\n const books = [];\n for (const item of data.data) {\n books.push({\n \"bookUrl\": `${currentBaseUrl}\/novel\/${item.novelId}?isSearch=1`,\n \"name\": item.novelName || \"\",\n \"author\": item.authorName || \"\",\n \"kind\": item.className ? item.className + \"小说\" : \"\",\n \"coverUrl\": item.cover || \"\",\n \"intro\": item.summary || \"\",\n \"tocUrl\": `${currentBaseUrl}\/novel\/${item.novelId}\/chapters?readNum=1`,\n \"wordCount\": item.wordNum || \"0\",\n \"type\": 0,\n \"latestChapterTitle\": \"\"\n });\n }\n\n return JSON.stringify(books);\n } catch (parseError) {\n flutterBridge.log(\"搜索解析错误: \" + parseError.message);\n return \"[]\";\n }\n } catch (error) {\n flutterBridge.log(\"搜索错误: \" + error.message);\n return \"[]\";\n }\n }\n\n async function info(bookurl) {\n try {\n const novelIdMatch = bookurl.match(\/\\\/novel\\\/(\\d+)\/);\n if (!novelIdMatch) {\n return JSON.stringify({\n \"bookUrl\": bookurl,\n \"name\": \"\",\n \"author\": \"\",\n \"kind\": \"\",\n \"coverUrl\": \"\",\n \"intro\": \"\",\n \"tocUrl\": \"\",\n \"wordCount\": \"\",\n \"type\": 0,\n \"latestChapterTitle\": \"\"\n });\n }\n \n const novelId = novelIdMatch[1];\n const url = `${currentBaseUrl}\/novel\/${novelId}?isSearch=1`;\n \n const response = await http.Get(url, JSON.stringify(headers), true);\n \n if (!response || !response.data) {\n return JSON.stringify({\n \"bookUrl\": bookurl,\n \"name\": \"\",\n \"author\": \"\",\n \"kind\": \"\",\n \"coverUrl\": \"\",\n \"intro\": \"\",\n \"tocUrl\": `${currentBaseUrl}\/novel\/${novelId}\/chapters?readNum=1`,\n \"wordCount\": \"\",\n \"type\": 0,\n \"latestChapterTitle\": \"\"\n });\n }\n\n flutterBridge.text(1, response.data);\n\n const data = JSON.parse(response.data);\n if (!data || !data.data) {\n return JSON.stringify({\n \"bookUrl\": bookurl,\n \"name\": \"\",\n \"author\": \"\",\n \"kind\": \"\",\n \"coverUrl\": \"\",\n \"intro\": \"\",\n \"tocUrl\": `${currentBaseUrl}\/novel\/${novelId}\/chapters?readNum=1`,\n \"wordCount\": \"\",\n \"type\": 0,\n \"latestChapterTitle\": \"\"\n });\n }\n\n const bookData = data.data;\n const lastChapterInfo = bookData.lastChapter ? \n `${cleanChapterName(bookData.lastChapter.chapterName)} ${bookData.lastChapter.decTime}` : \"\";\n \n const bookInfo = {\n \"bookUrl\": bookurl,\n \"name\": bookData.novelName || \"\",\n \"author\": bookData.authorName || \"\",\n \"kind\": `${bookData.className || \"\"},${bookData.tagName || \"\"}`,\n \"coverUrl\": bookData.cover || \"\",\n \"intro\": cleanIntro(bookData.summary || \"\"),\n \"tocUrl\": `${currentBaseUrl}\/novel\/${novelId}\/chapters?readNum=1`,\n \"wordCount\": bookData.wordNum || \"0\",\n \"type\": 0,\n \"latestChapterTitle\": lastChapterInfo\n };\n\n return JSON.stringify(bookInfo);\n } catch (error) {\n flutterBridge.log(\"书籍详情错误: \" + error.message);\n return JSON.stringify({\n \"bookUrl\": bookurl,\n \"name\": \"\",\n \"author\": \"\",\n \"kind\": \"\",\n \"coverUrl\": \"\",\n \"intro\": \"\",\n \"tocUrl\": \"\",\n \"wordCount\": \"\",\n \"type\": 0,\n \"latestChapterTitle\": \"\"\n });\n }\n }\n\n async function chapter(tocUrl, bookurl) {\n try {\n const chaptersUrl = tocUrl || `${currentBaseUrl}\/novel\/1\/chapters?readNum=1`;\n \n const response = await http.Get(chaptersUrl, JSON.stringify(headers), true);\n \n if (!response || !response.data) {\n return \"[]\";\n }\n\n flutterBridge.text(2, response.data);\n\n const data = JSON.parse(response.data);\n if (!data || !data.data || !data.data.list || !Array.isArray(data.data.list)) {\n return \"[]\";\n }\n\n const chapters = [];\n const chapterList = data.data.list;\n \n for (let i = 0; i < chapterList.length; i++) {\n const chapterItem = chapterList[i];\n const chapterUrl = aesDecrypt(chapterItem.path);\n \n chapters.push({\n \"name\": cleanChapterName(chapterItem.chapterName || \"\"),\n \"chapterId\": JSON.stringify({\n chapterUrl: chapterUrl,\n chapterId: chapterItem.chapterId\n }),\n \"index\": i,\n \"isPay\": false,\n \"isVip\": false,\n \"isVolume\": false,\n \"tag\": `${chapterItem.updatedAt || \"\"} 字数:${chapterItem.wordNum || \"0\"}`\n });\n }\n\n return JSON.stringify(chapters);\n } catch (error) {\n flutterBridge.log(\"目录获取错误: \" + error.message);\n return \"[]\";\n }\n }\n\n async function content(url, bookurl) {\n try {\n const chapterData = JSON.parse(url);\n const chapterUrl = chapterData.chapterUrl;\n \n if (!chapterUrl) return \"章节URL无效\";\n\n const response = await http.Get(chapterUrl, JSON.stringify(headers), true);\n \n if (!response || !response.data) {\n return \"获取内容失败\";\n }\n\n flutterBridge.text(3, response.data.substring(0, 500) + \"...\");\n\n const data = JSON.parse(response.data);\n if (!data || !data.content) {\n return \"未找到正文内容\";\n }\n\n return cleanContent(data.content);\n } catch (error) {\n flutterBridge.log(\"正文获取错误: \" + error.message);\n return \"获取正文失败: \" + error.message;\n }\n }\n\n async function getfinds() {\n const finds = [\n {\n \"title\": \"男频榜单\",\n \"url\": \"\",\n \"type\": 0,\n \"width\": 3\n },\n {\n \"title\": \"必读榜\",\n \"url\": JSON.stringify({\n url: \"\/module\/rank?type=1&channel=1&page={{page}}\",\n type: \"rank\"\n }),\n \"type\": 0,\n \"width\": 0\n },\n {\n \"title\": \"潜力榜\",\n \"url\": JSON.stringify({\n url: \"\/module\/rank?type=5&channel=1&page={{page}}\",\n type: \"rank\"\n }),\n \"type\": 0,\n \"width\": 0\n },\n {\n \"title\": \"完本榜\",\n \"url\": JSON.stringify({\n url: \"\/module\/rank?type=2&channel=1&page={{page}}\",\n type: \"rank\"\n }),\n \"type\": 0,\n \"width\": 0\n },\n {\n \"title\": \"更新榜\",\n \"url\": JSON.stringify({\n url: \"\/module\/rank?type=3&channel=1&page={{page}}\",\n type: \"rank\"\n }),\n \"type\": 0,\n \"width\": 0\n },\n {\n \"title\": \"搜索榜\",\n \"url\": JSON.stringify({\n url: \"\/module\/rank?type=4&channel=1&page={{page}}\",\n type: \"rank\"\n }),\n \"type\": 0,\n \"width\": 0\n },\n {\n \"title\": \"评论榜\",\n \"url\": JSON.stringify({\n url: \"\/module\/rank?type=6&channel=1&page={{page}}\",\n type: \"rank\"\n }),\n \"type\": 0,\n \"width\": 0\n },\n {\n \"title\": \"男频全部\",\n \"url\": \"\",\n \"type\": 0,\n \"width\": 3\n },\n {\n \"title\": \"玄幻\",\n \"url\": JSON.stringify({\n url: \"\/novel?sort=1&page={{page}}&categoryId=lejRej\",\n type: \"category\"\n }),\n \"type\": 0,\n \"width\": 0\n },\n {\n \"title\": \"武侠\",\n \"url\": JSON.stringify({\n url: \"\/novel?sort=1&page={{page}}&categoryId=nel5aK\",\n type: \"category\"\n }),\n \"type\": 0,\n \"width\": 0\n },\n {\n \"title\": \"都市\",\n \"url\": JSON.stringify({\n url: \"\/novel?sort=1&page={{page}}&categoryId=mbk5ez\",\n type: \"category\"\n }),\n \"type\": 0,\n \"width\": 0\n },\n {\n \"title\": \"仙侠\",\n \"url\": JSON.stringify({\n url: \"\/novel?sort=1&page={{page}}&categoryId=vbmOeY\",\n type: \"category\"\n }),\n \"type\": 0,\n \"width\": 0\n },\n {\n \"title\": \"军事\",\n \"url\": JSON.stringify({\n url: \"\/novel?sort=1&page={{page}}&categoryId=penRe7\",\n type: \"category\"\n }),\n \"type\": 0,\n \"width\": 0\n },\n {\n \"title\": \"历史\",\n \"url\": JSON.stringify({\n url: \"\/novel?sort=1&page={{page}}&categoryId=xbojag\",\n type: \"category\"\n }),\n \"type\": 0,\n \"width\": 0\n },\n {\n \"title\": \"游戏\",\n \"url\": JSON.stringify({\n url: \"\/novel?sort=1&page={{page}}&categoryId=mep2bM\",\n type: \"category\"\n }),\n \"type\": 0,\n \"width\": 0\n },\n {\n \"title\": \"科幻\",\n \"url\": JSON.stringify({\n url: \"\/novel?sort=1&page={{page}}&categoryId=zbq2dp\",\n type: \"category\"\n }),\n \"type\": 0,\n \"width\": 0\n },\n {\n \"title\": \"轻小说\",\n \"url\": JSON.stringify({\n url: \"\/novel?sort=1&page={{page}}&categoryId=YerEdO\",\n type: \"category\"\n }),\n \"type\": 0,\n \"width\": 0\n },\n {\n \"title\": \"男频完结\",\n \"url\": \"\",\n \"type\": 0,\n \"width\": 3\n },\n {\n \"title\": \"玄幻\",\n \"url\": JSON.stringify({\n url: \"\/novel?sort=1&page={{page}}&categoryId=lejRej&isComplete=1\",\n type: \"category\"\n }),\n \"type\": 0,\n \"width\": 0\n },\n {\n \"title\": \"武侠\",\n \"url\": JSON.stringify({\n url: \"\/novel?sort=1&page={{page}}&categoryId=nel5aK&isComplete=1\",\n type: \"category\"\n }),\n \"type\": 0,\n \"width\": 0\n },\n {\n \"title\": \"都市\",\n \"url\": JSON.stringify({\n url: \"\/novel?sort=1&page={{page}}&categoryId=mbk5ez&isComplete=1\",\n type: \"category\"\n }),\n \"type\": 0,\n \"width\": 0\n },\n {\n \"title\": \"仙侠\",\n \"url\": JSON.stringify({\n url: \"\/novel?sort=1&page={{page}}&categoryId=vbmOeY&isComplete=1\",\n type: \"category\"\n }),\n \"type\": 0,\n \"width\": 0\n },\n {\n \"title\": \"军事\",\n \"url\": JSON.stringify({\n url: \"\/novel?sort=1&page={{page}}&categoryId=penRe7&isComplete=1\",\n type: \"category\"\n }),\n \"type\": 0,\n \"width\": 0\n },\n {\n \"title\": \"历史\",\n \"url\": JSON.stringify({\n url: \"\/novel?sort=1&page={{page}}&categoryId=xbojag&isComplete=1\",\n type: \"category\"\n }),\n \"type\": 0,\n \"width\": 0\n },\n {\n \"title\": \"游戏\",\n \"url\": JSON.stringify({\n url: \"\/novel?sort=1&page={{page}}&categoryId=mep2bM&isComplete=1\",\n type: \"category\"\n }),\n \"type\": 0,\n \"width\": 0\n },\n {\n \"title\": \"科幻\",\n \"url\": JSON.stringify({\n url: \"\/novel?sort=1&page={{page}}&categoryId=zbq2dp&isComplete=1\",\n type: \"category\"\n }),\n \"type\": 0,\n \"width\": 0\n },\n {\n \"title\": \"轻小说\",\n \"url\": JSON.stringify({\n url: \"\/novel?sort=1&page={{page}}&categoryId=YerEdO&isComplete=1\",\n type: \"category\"\n }),\n \"type\": 0,\n \"width\": 0\n },\n {\n \"title\": \"男频连载\",\n \"url\": \"\",\n \"type\": 0,\n \"width\": 3\n },\n {\n \"title\": \"玄幻\",\n \"url\": JSON.stringify({\n url: \"\/novel?sort=1&page={{page}}&categoryId=lejRej&isComplete=0\",\n type: \"category\"\n }),\n \"type\": 0,\n \"width\": 0\n },\n {\n \"title\": \"武侠\",\n \"url\": JSON.stringify({\n url: \"\/novel?sort=1&page={{page}}&categoryId=nel5aK&isComplete=0\",\n type: \"category\"\n }),\n \"type\": 0,\n \"width\": 0\n },\n {\n \"title\": \"都市\",\n \"url\": JSON.stringify({\n url: \"\/novel?sort=1&page={{page}}&categoryId=mbk5ez&isComplete=0\",\n type: \"category\"\n }),\n \"type\": 0,\n \"width\": 0\n },\n {\n \"title\": \"仙侠\",\n \"url\": JSON.stringify({\n url: \"\/novel?sort=1&page={{page}}&categoryId=vbmOeY&isComplete=0\",\n type: \"category\"\n }),\n \"type\": 0,\n \"width\": 0\n },\n {\n \"title\": \"军事\",\n \"url\": JSON.stringify({\n url: \"\/novel?sort=1&page={{page}}&categoryId=penRe7&isComplete=0\",\n type: \"category\"\n }),\n \"type\": 0,\n \"width\": 0\n },\n {\n \"title\": \"历史\",\n \"url\": JSON.stringify({\n url: \"\/novel?sort=1&page={{page}}&categoryId=xbojag&isComplete=0\",\n type: \"category\"\n }),\n \"type\": 0,\n \"width\": 0\n },\n {\n \"title\": \"游戏\",\n \"url\": JSON.stringify({\n url: \"\/novel?sort=1&page={{page}}&categoryId=mep2bM&isComplete=0\",\n type: \"category\"\n }),\n \"type\": 0,\n \"width\": 0\n },\n {\n \"title\": \"科幻\",\n \"url\": JSON.stringify({\n url: \"\/novel?sort=1&page={{page}}&categoryId=zbq2dp&isComplete=0\",\n type: \"category\"\n }),\n \"type\": 0,\n \"width\": 0\n },\n {\n \"title\": \"轻小说\",\n \"url\": JSON.stringify({\n url: \"\/novel?sort=1&page={{page}}&categoryId=YerEdO&isComplete=0\",\n type: \"category\"\n }),\n \"type\": 0,\n \"width\": 0\n },\n {\n \"title\": \"女频榜单\",\n \"url\": \"\",\n \"type\": 0,\n \"width\": 3\n },\n {\n \"title\": \"必读榜\",\n \"url\": JSON.stringify({\n url: \"\/module\/rank?type=1&channel=2&page={{page}}\",\n type: \"rank\"\n }),\n \"type\": 0,\n \"width\": 0\n },\n {\n \"title\": \"潜力榜\",\n \"url\": JSON.stringify({\n url: \"\/module\/rank?type=5&channel=2&page={{page}}\",\n type: \"rank\"\n }),\n \"type\": 0,\n \"width\": 0\n },\n {\n \"title\": \"完本榜\",\n \"url\": JSON.stringify({\n url: \"\/module\/rank?type=2&channel=2&page={{page}}\",\n type: \"rank\"\n }),\n \"type\": 0,\n \"width\": 0\n },\n {\n \"title\": \"更新榜\",\n \"url\": JSON.stringify({\n url: \"\/module\/rank?type=3&channel=2&page={{page}}\",\n type: \"rank\"\n }),\n \"type\": 0,\n \"width\": 0\n },\n {\n \"title\": \"搜索榜\",\n \"url\": JSON.stringify({\n url: \"\/module\/rank?type=4&channel=2&page={{page}}\",\n type: \"rank\"\n }),\n \"type\": 0,\n \"width\": 0\n },\n {\n \"title\": \"评论榜\",\n \"url\": JSON.stringify({\n url: \"\/module\/rank?type=6&channel=2&page={{page}}\",\n type: \"rank\"\n }),\n \"type\": 0,\n \"width\": 0\n },\n {\n \"title\": \"女频全部\",\n \"url\": \"\",\n \"type\": 0,\n \"width\": 3\n },\n {\n \"title\": \"现代言情\",\n \"url\": JSON.stringify({\n url: \"\/novel?sort=1&page={{page}}&categoryId=9avmeG\",\n type: \"category\"\n }),\n \"type\": 0,\n \"width\": 0\n },\n {\n \"title\": \"古代言情\",\n \"url\": JSON.stringify({\n url: \"\/novel?sort=1&page={{page}}&categoryId=DdwRb1\",\n type: \"category\"\n }),\n \"type\": 0,\n \"width\": 0\n },\n {\n \"title\": \"幻想言情\",\n \"url\": JSON.stringify({\n url: \"\/novel?sort=1&page={{page}}&categoryId=7ax9by\",\n type: \"category\"\n }),\n \"type\": 0,\n \"width\": 0\n },\n {\n \"title\": \"青春校园\",\n \"url\": JSON.stringify({\n url: \"\/novel?sort=1&page={{page}}&categoryId=Pdy7aQ\",\n type: \"category\"\n }),\n \"type\": 0,\n \"width\": 0\n },\n {\n \"title\": \"唯美纯爱\",\n \"url\": JSON.stringify({\n url: \"\/novel?sort=1&page={{page}}&categoryId=kazYeJ\",\n type: \"category\"\n }),\n \"type\": 0,\n \"width\": 0\n },\n {\n \"title\": \"同人衍生\",\n \"url\": JSON.stringify({\n url: \"\/novel?sort=1&page={{page}}&categoryId=9aAOdv\",\n type: \"category\"\n }),\n \"type\": 0,\n \"width\": 0\n },\n {\n \"title\": \"女频完结\",\n \"url\": \"\",\n \"type\": 0,\n \"width\": 3\n },\n {\n \"title\": \"现代言情\",\n \"url\": JSON.stringify({\n url: \"\/novel?sort=1&page={{page}}&categoryId=9avmeG&isComplete=1\",\n type: \"category\"\n }),\n \"type\": 0,\n \"width\": 0\n },\n {\n \"title\": \"古代言情\",\n \"url\": JSON.stringify({\n url: \"\/novel?sort=1&page={{page}}&categoryId=DdwRb1&isComplete=1\",\n type: \"category\"\n }),\n \"type\": 0,\n \"width\": 0\n },\n {\n \"title\": \"幻想言情\",\n \"url\": JSON.stringify({\n url: \"\/novel?sort=1&page={{page}}&categoryId=7ax9by&isComplete=1\",\n type: \"category\"\n }),\n \"type\": 0,\n \"width\": 0\n },\n {\n \"title\": \"青春校园\",\n \"url\": JSON.stringify({\n url: \"\/novel?sort=1&page={{page}}&categoryId=Pdy7aQ&isComplete=1\",\n type: \"category\"\n }),\n \"type\": 0,\n \"width\": 0\n },\n {\n \"title\": \"唯美纯爱\",\n \"url\": JSON.stringify({\n url: \"\/novel?sort=1&page={{page}}&categoryId=kazYeJ&isComplete=1\",\n type: \"category\"\n }),\n \"type\": 0,\n \"width\": 0\n },\n {\n \"title\": \"同人衍生\",\n \"url\": JSON.stringify({\n url: \"\/novel?sort=1&page={{page}}&categoryId=9aAOdv&isComplete=1\",\n type: \"category\"\n }),\n \"type\": 0,\n \"width\": 0\n },\n {\n \"title\": \"女频连载\",\n \"url\": \"\",\n \"type\": 0,\n \"width\": 3\n },\n {\n \"title\": \"现代言情\",\n \"url\": JSON.stringify({\n url: \"\/novel?sort=1&page={{page}}&categoryId=9avmeG&isComplete=0\",\n type: \"category\"\n }),\n \"type\": 0,\n \"width\": 0\n },\n {\n \"title\": \"古代言情\",\n \"url\": JSON.stringify({\n url: \"\/novel?sort=1&page={{page}}&categoryId=DdwRb1&isComplete=0\",\n type: \"category\"\n }),\n \"type\": 0,\n \"width\": 0\n },\n {\n \"title\": \"幻想言情\",\n \"url\": JSON.stringify({\n url: \"\/novel?sort=1&page={{page}}&categoryId=7ax9by&isComplete=0\",\n type: \"category\"\n }),\n \"type\": 0,\n \"width\": 0\n },\n {\n \"title\": \"青春校园\",\n \"url\": JSON.stringify({\n url: \"\/novel?sort=1&page={{page}}&categoryId=Pdy7aQ&isComplete=0\",\n type: \"category\"\n }),\n \"type\": 0,\n \"width\": 0\n },\n {\n \"title\": \"唯美纯爱\",\n \"url\": JSON.stringify({\n url: \"\/novel?sort=1&page={{page}}&categoryId=kazYeJ&isComplete=0\",\n type: \"category\"\n }),\n \"type\": 0,\n \"width\": 0\n },\n {\n \"title\": \"同人衍生\",\n \"url\": JSON.stringify({\n url: \"\/novel?sort=1&page={{page}}&categoryId=9aAOdv&isComplete=0\",\n type: \"category\"\n }),\n \"type\": 0,\n \"width\": 0\n }\n ];\n \n return JSON.stringify(finds);\n }\n\n async function find(url, page) {\n try {\n if (!url) return \"[]\";\n \n const findData = JSON.parse(url);\n if (!findData.url) return \"[]\";\n \n let actualUrl = findData.url.replace(\"{{page}}\", page || \"1\");\n \n if (!actualUrl.startsWith(\"http\")) {\n actualUrl = currentBaseUrl + actualUrl;\n }\n \n const response = await http.Get(actualUrl, JSON.stringify(headers), true);\n \n if (!response || !response.data) {\n return \"[]\";\n }\n\n flutterBridge.text(0, response.data);\n\n const data = JSON.parse(response.data);\n if (!data || !data.data || !Array.isArray(data.data)) {\n return \"[]\";\n }\n\n const books = [];\n for (const item of data.data) {\n books.push({\n \"bookUrl\": `${currentBaseUrl}\/novel\/${item.novelId}?isSearch=1`,\n \"name\": item.novelName || \"\",\n \"author\": item.authorName || \"\",\n \"kind\": item.className || \"\",\n \"coverUrl\": item.cover || \"\",\n \"intro\": item.summary || \"\",\n \"tocUrl\": `${currentBaseUrl}\/novel\/${item.novelId}\/chapters?readNum=1`,\n \"wordCount\": item.wordNum || \"0\",\n \"type\": 0,\n \"latestChapterTitle\": \"\"\n });\n }\n\n return JSON.stringify(books);\n } catch (error) {\n flutterBridge.log(\"发现页面错误: \" + error.message);\n return \"[]\";\n }\n }\n\n async function getloginurl() {\n return currentBaseUrl;\n }\n\n async function login() {\n }\n\n async function pay(bookurl, url) {\n }\n\n async function imagedecrypt(url, image) {\n return [];\n }\n\n async function shouldOverrideUrlLoading(url) {\n return true;\n }\n\n async function gethelp() {\n }\n<\/script>\n<\/html>",
"login": true,
"lastUpdateTime": "1770977517744"
}