爱下电子书

https://apiv2hans.aixdzs.com

autobcb_admin (12020)3天前

爱下电子书 作者 清词

二维码导入(APP尚未完成该功能)
{
    "bookSourceUrl": "https:\/\/apiv2hans.aixdzs.com",
    "bookSourceName": "爱下电子书",
    "enabledExplore": true,
    "enabled": true,
    "bookSourceGroup": "",
    "author": "清词",
    "help": false,
    "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:\/\/cdnjs.cloudflare.com\/ajax\/libs\/js-sha1\/0.6.0\/sha1.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 baseurl = \"https:\/\/apiv2hans.aixdzs.com\";\n    var header = {\n      \"User-Agent\": \"Dalvik\/2.1.0 (Linux; U; Android 10; MIX Build\/PKQ1.190118.001)\",\n      \"Content-Type\": \"application\/json; charset=UTF-8\"\n    };\n\n    function cleanChapterTitle(title) {\n      if (!title) return '';\n      let cleaned = title\n        .replace(\"••\", \"\")\n        .replace(\/^(\\d+).第\/, '第')\n        .replace(\/^(正文|VIP章节|最新章节)?(\\s+|_)|[\\((【].*[求更谢乐发推票盟补加字Kk\\\/].*[)】\\)]\/g, '')\n        .replace(\/^(\\d+)[、.]第.+章\/, '第$1章')\n        .replace(\/^(\\d+)、\\d+、\/, '第$1章 ')\n        .replace(\/^(\\d+)、\\d+\/, '第$1章')\n        .replace(\/^(第.+章)\\s?\\d+\/, '$1')\n        .replace(\/^(\\d+)、\/, '第$1章 ')\n        .replace(\/^(第.+章)\\s?第.+章\/, '$1')\n        .replace(\/第\\s(.+)\\s章\/, '第$1章')\n        .replace(\/.*(chapter|Chapter)\\s?(\\d+)\\s?\/, '$1 $2 ')\n        .replace(\/\\(.+\\)\/, '')\n        .replace(\/\\[|。\/g, '');\n      return cleaned.trim();\n    }\n\n    function generateNonce(length = 8) {\n      const chars = 'abcdefghijklmnopqrstuvwxyz0123456789';\n      let result = '';\n      for (let i = 0; i < length; i++) {\n        const randomIndex = Math.floor(Math.random() * chars.length);\n        result += chars[randomIndex];\n      }\n      return result;\n    }\n\n    async function search(key, page) {\n      var postData = {\n        searchTerms: key,\n        pageSize: \"20\",\n        pageNum: page.toString()\n      };\n      \n      var url = baseurl + \"\/search\";\n      var get = await http.Post(url, JSON.stringify(header), JSON.stringify(postData), \"application\/json\", true);\n      var result = get.data;\n      \n      flutterBridge.text(0, result);\n      var books = [];\n      \n      try {\n        var data = JSON.parse(result);\n        if (data && data.data && data.data.bookList) {\n          var bookList = data.data.bookList;\n          \n          for (var i = 0; i < bookList.length; i++) {\n            var book = bookList[i];\n            \n            var updated = book.updated || \"\";\n            var cat = book.cat || \"\";\n            var zt = book.zt || \"\";\n            var kind = \"\";\n            \n            if (updated) kind += updated.replace(\/T.*\/, '') + \"\\n\";\n            if (cat) kind += cat + \"\\n\";\n            if (zt) kind += zt;\n            \n            var lastChapter = book.lastChapter || \"\";\n            lastChapter = lastChapter.replace(\/最新[::]\/, '');\n            var lastChapterFull = cleanChapterTitle(lastChapter + \" • \" + (updated ? updated.replace(\/T.*\/, '') : \"\"));\n            \n            var bookInfo = {\n              \"bookUrl\": JSON.stringify({bookId: book.bookId}),\n              \"name\": book.title || \"\",\n              \"author\": book.author || \"\",\n              \"kind\": kind.trim(),\n              \"coverUrl\": \"https:\/\/img22.aixdzs.com\/\" + (book.cover || \"\") + \",\" + JSON.stringify({\"headers\": header}),\n              \"intro\": book.shortIntro || \"\",\n              \"tocUrl\": JSON.stringify({bookId: book.bookId}),\n              \"wordCount\": book.wordCount || \"\",\n              \"type\": 0,\n              \"latestChapterTitle\": lastChapterFull\n            };\n            \n            books.push(bookInfo);\n          }\n        }\n      } catch (error) {\n        return \"[]\";\n      }\n      \n      return JSON.stringify(books);\n    }\n\n    async function info(bookurl) {\n      try {\n        var bookData = JSON.parse(bookurl);\n        var bookId = bookData.bookId;\n        \n        var postData = {\n          bookId: bookId\n        };\n        \n        var url = baseurl + \"\/book\/detail\";\n        var get = await http.Post(url, JSON.stringify(header), JSON.stringify(postData), \"application\/json\", true);\n        var result = get.data;\n        \n        flutterBridge.text(1, result);\n        \n        var book = {\n          \"bookUrl\": bookurl,\n          \"name\": \"\",\n          \"author\": \"\",\n          \"kind\": \"\",\n          \"coverUrl\": \"\",\n          \"intro\": \"\",\n          \"tocUrl\": bookurl,\n          \"wordCount\": \"\",\n          \"type\": 0,\n          \"latestChapterTitle\": \"\"\n        };\n        \n        try {\n          var data = JSON.parse(result);\n          if (data && data.data && data.data.book) {\n            var bookInfo = data.data.book;\n            \n            var updated = bookInfo.updated || \"\";\n            var cat = bookInfo.cat || \"\";\n            var zt = bookInfo.zt || \"\";\n            var kind = \"\";\n            \n            if (updated) kind += updated.replace(\/T.*\/, '') + \"\\n\";\n            if (cat) kind += cat + \"\\n\";\n            if (zt) kind += zt;\n            \n            var lastChapter = bookInfo.lastChapter || \"\";\n            var lastChapterFull = cleanChapterTitle(lastChapter);\n            \n            book = {\n              \"bookUrl\": bookurl,\n              \"name\": bookInfo.title || \"\",\n              \"author\": bookInfo.author || \"\",\n              \"kind\": kind.trim(),\n              \"coverUrl\": \"https:\/\/img22.aixdzs.com\/\" + (bookInfo.cover || \"\") + \",\" + JSON.stringify({\"headers\": header}),\n              \"intro\": bookInfo.longIntro || \"\",\n              \"tocUrl\": JSON.stringify({bookId: bookId}),\n              \"wordCount\": bookInfo.wordCount || \"\",\n              \"type\": 0,\n              \"latestChapterTitle\": lastChapterFull\n            };\n          }\n        } catch (error) {\n          return JSON.stringify(book);\n        }\n        \n        return JSON.stringify(book);\n      } catch (error) {\n        return JSON.stringify({\n          \"bookUrl\": bookurl,\n          \"name\": \"\",\n          \"author\": \"\",\n          \"kind\": \"\",\n          \"coverUrl\": \"\",\n          \"intro\": \"\",\n          \"tocUrl\": bookurl,\n          \"wordCount\": \"\",\n          \"type\": 0,\n          \"latestChapterTitle\": \"\"\n        });\n      }\n    }\n\n    async function chapter(tocUrl, bookurl) {\n      try {\n        var bookData = JSON.parse(tocUrl);\n        var bookId = bookData.bookId;\n        \n        var postData = {\n          bookId: bookId\n        };\n        \n        var url = baseurl + \"\/catalog\";\n        var get = await http.Post(url, JSON.stringify(header), JSON.stringify(postData), \"application\/json\", true);\n        var result = get.data;\n        \n        flutterBridge.text(2, result);\n        \n        var chapters = [];\n        \n        try {\n          var data = JSON.parse(result);\n          if (data && data.data && data.data.chapterList) {\n            var chapterList = data.data.chapterList;\n            \n            for (var i = 0; i < chapterList.length; i++) {\n              var chapterInfo = chapterList[i];\n              \n              var chapter = {\n                \"name\": chapterInfo.chapterName || \"\",\n                \"chapterId\": JSON.stringify({\n                  chapterId: chapterInfo.chapterId,\n                  bookId: bookId\n                }),\n                \"index\": i,\n                \"isPay\": false,\n                \"isVip\": false,\n                \"isVolume\": false,\n                \"tag\": \"\"\n              };\n              \n              chapters.push(chapter);\n            }\n          }\n        } catch (error) {\n          return \"[]\";\n        }\n        \n        return JSON.stringify(chapters);\n      } catch (error) {\n        return \"[]\";\n      }\n    }\n\n    async function content(url, bookurl) {\n      try {\n        var chapterData = JSON.parse(url);\n        var chapterId = chapterData.chapterId;\n        var bookId = chapterData.bookId;\n        \n        var s = \"2c6689f91ee4d4e87d798397d47310ebbe1dad79ixdzs\";\n        var h = generateNonce(8);\n        var a = Math.round(Date.now() \/ 1000).toString();\n        var sha = s + h + a + h;\n        \n        var sha1Hash = sha1(sha);\n        \n        var customHeader = Object.assign({}, header);\n        customHeader[\"checkSumDTO\"] = JSON.stringify({\n          appid: \"ixdzs\",\n          checksum: sha1Hash,\n          curtime: a,\n          nonce: h\n        });\n        \n        var postData = {\n          chapterId: parseInt(chapterId),\n          bookId: bookId\n        };\n        \n        var apiUrl = baseurl + \"\/chapter\/content\";\n        var get = await http.Post(apiUrl, JSON.stringify(customHeader), JSON.stringify(postData), \"application\/json\", true);\n        var result = get.data;\n        \n        flutterBridge.text(3, result);\n        \n        var content = \"\";\n        \n        try {\n          var data = JSON.parse(result);\n          if (data && data.data && data.data.chapter && data.data.chapter.chapterContent) {\n            content = data.data.chapter.chapterContent || \"\";\n            content = content.replace(\/\\n\\s*[((]本章完[))]$|\\n\\s*第.*章.*\\n|.*武林中文网.*最新章节!\/g, '');\n          }\n        } catch (error) {\n          return \"\";\n        }\n        \n        return content;\n      } catch (error) {\n        return \"\";\n      }\n    }\n\n    async function getfinds() {\n      var url = baseurl + \"\/sort\";\n      var get = await http.Get(url, JSON.stringify(header), true);\n      var result = get.data;\n      \n      var finds = [];\n      \n      try {\n        var data = JSON.parse(result);\n        if (data && data.data && data.data.allType) {\n          var allType = data.data.allType;\n          \n          finds.push({\n            \"title\": \"最新\",\n            \"url\": \"\",\n            \"type\": 0,\n            \"width\": 3\n          });\n          \n          for (var i = 0; i < allType.length; i++) {\n            var type = allType[i];\n            finds.push({\n              \"title\": type.categoryName,\n              \"url\": JSON.stringify({\n                url: baseurl + \"\/sortlist\",\n                data: {\n                  bookTypeId: type.bookTypeId,\n                  type: \"1\",\n                  pageNum: \"{{page}}\"\n                }\n              }),\n              \"type\": 0,\n              \"width\": 0\n            });\n          }\n          \n          finds.push({\n            \"title\": \"大热\",\n            \"url\": \"\",\n            \"type\": 0,\n            \"width\": 3\n          });\n          \n          for (var i = 0; i < allType.length; i++) {\n            var type = allType[i];\n            finds.push({\n              \"title\": type.categoryName,\n              \"url\": JSON.stringify({\n                url: baseurl + \"\/sortlist\",\n                data: {\n                  bookTypeId: type.bookTypeId,\n                  type: \"2\",\n                  pageNum: \"{{page}}\"\n                }\n              }),\n              \"type\": 0,\n              \"width\": 0\n            });\n          }\n        }\n      } catch (error) {\n        return \"[]\";\n      }\n      \n      return JSON.stringify(finds);\n    }\n\n    async function find(url, page) {\n      try {\n        if (!url || url === \"\") return \"[]\";\n        \n        var requestData = JSON.parse(url);\n        \n        if (!requestData.url || !requestData.data) return \"[]\";\n        \n        var postData = Object.assign({}, requestData.data);\n        if (page) {\n          postData.pageNum = page.toString();\n        }\n        \n        var apiUrl = requestData.url;\n        var get = await http.Post(apiUrl, JSON.stringify(header), JSON.stringify(postData), \"application\/json\", true);\n        var result = get.data;\n        \n        flutterBridge.text(0, result);\n        \n        var books = [];\n        \n        try {\n          var data = JSON.parse(result);\n          if (data && data.data && data.data.bookList) {\n            var bookList = data.data.bookList;\n            \n            for (var i = 0; i < bookList.length; i++) {\n              var book = bookList[i];\n              \n              var updated = book.updated || \"\";\n              var cat = book.cat || \"\";\n              var zt = book.zt || \"\";\n              var kind = \"\";\n              \n              if (updated) kind += updated.replace(\/T.*\/, '') + \"\\n\";\n              if (cat) kind += cat + \"\\n\";\n              if (zt) kind += zt;\n              \n              var lastChapter = book.lastChapter || \"\";\n              lastChapter = lastChapter.replace(\/最新[::]\/, '');\n              var lastChapterFull = cleanChapterTitle(lastChapter + \" • \" + (updated ? updated.replace(\/T.*\/, '') : \"\"));\n              \n              var bookInfo = {\n                \"bookUrl\": JSON.stringify({bookId: book.bookId}),\n                \"name\": book.title || \"\",\n                \"author\": book.author || \"\",\n                \"kind\": kind.trim(),\n                \"coverUrl\": \"https:\/\/img22.aixdzs.com\/\" + (book.cover || \"\") + \",\" + JSON.stringify({\"headers\": header}),\n                \"intro\": book.shortIntro || \"\",\n                \"tocUrl\": JSON.stringify({bookId: book.bookId}),\n                \"wordCount\": book.wordCount || \"\",\n                \"type\": 0,\n                \"latestChapterTitle\": lastChapterFull\n              };\n              \n              books.push(bookInfo);\n            }\n          }\n        } catch (error) {\n          return \"[]\";\n        }\n        \n        return JSON.stringify(books);\n      } catch (error) {\n        return \"[]\";\n      }\n    }\n\n    async function getloginurl() {\n      return baseurl;\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": false,
    "lastUpdateTime": "1770978045819"
}
广告