🎨 漫蛙

http://manwaso.cc

autobcb_admin (12020)2小时前

部分地区需要 vpn
二维码导入(APP尚未完成该功能)
{
    "bookSourceUrl": "http:\/\/manwaso.cc",
    "bookSourceName": "🎨 漫蛙",
    "enabledExplore": true,
    "enabled": true,
    "bookSourceGroup": "漫画",
    "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\/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    \/\/获取设备唯一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    \/\/获取默认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    \/**\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    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    \/\/提交内容书本信息 json 后的字符串\n    async addbook(book) {\n      try {\n        return await window.flutter_inappwebview.callHandler('addbook',book);\n      } catch (error) {\n        return  \"\";\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请勿使用\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  var baseurl=\"http:\/\/manwaso.cc\";\n  var header={\n    \"User-Agent\":\"Mozilla\/5.0 (Linux; Android 11; V1981A) AppleWebKit\/537.36 (KHTML, like Gecko) Chrome\/107.0.0.0 Mobile Safari\/537.36\",\n    \"Cookie\":\"ckc=1;\",\n  }\n\n  async function search(key,page) {\n    var url=baseurl+\"\/search?keyword={{key}}&page={{page}}\".replace(\"{{page}}\",page).replace(\"{{key}}\",encodeURIComponent(key));\n    var get= await  http.Get(url,JSON.stringify(header),true);\n    var result=get.data;\n    flutterBridge.text(0,result )\n    var books=[];\n    var html = $.parseHTML( result );\n    $(html).find(\".book-list\").find(\"li\").each(function(index) {\n      var $element = $(this);\n      var img = $element.find(\"img\").attr('data-original');\n      if(img.trim() == '') {\n        img= $element.find(\"img\").attr('src');\n      }\n      var book={\n        \"bookUrl\":baseurl+$element.find(\"a\").eq(0).attr('href'),\n        \"name\": $element.find(\".book-list-info-title\").text(),\n        \"author\": $element.find(\".book-list-info-bottom-item\").eq(0).text(),\n        \"kind\":  $element.find(\"span\").eq(2).text(),\n        \"coverUrl\":img.trim()+\",\"+JSON.stringify({\"headers\":header}),\n        \"intro\":$element.find(\".book-list-info-desc\").text(),\n        \"tocUrl\":baseurl+$element.find(\"a\").eq(0).attr('href'),\n        \"wordCount\":\"\",\n        \"type\":2,\n        \"latestChapterTitle\":\"\",\n      }\n      books.push(book);\n    });\n    return JSON.stringify(books);\n  }\n\n  async function info(bookurl) {\n    var get=await http.Get(bookurl,JSON.stringify({\n      ...header,\n      \"Referer\":bookurl,\n    }),true);\n    flutterBridge.text(1,get.data );\n    var html = $.parseHTML( get.data );\n    var author=\"\";\n    $(html).find(\".detail-main-info-author\").find(\".detail-main-info-value\").eq(1).find(\"a\").each(function(index) {\n      var $element = $(this);\n      if(author == \"\"){\n        author=$element.text().trim();\n      }else{\n        author=author +\",\"+$element.text().trim();\n      }\n    });\n    var kind=\"\"\n    $(html).find(\".detail-main-info-class\").find(\"a\").each(function(index) {\n      var $element = $(this);\n      if(kind == \"\"){\n        kind=$element.text().trim();\n      }else{\n        kind=kind +\",\"+$element.text().trim();\n      }\n    });\n    var img = $(html).find(\".detail-main-bg\").attr('data-original');\n    var latestChapterTitle=\"\";\n    var list=$(html).find(\"#detail-list-select\").find(\"li\")\n    if(list.length > 0){\n      latestChapterTitle=list.eq(list.length-1).text().trim();\n    }\n    var book={\n      \"bookUrl\":bookurl,\n      \"name\":$(html).find(\".detail-main-info-title\").text(),\n      \"author\":author,\n      \"kind\":kind,\n      \"coverUrl\":img,\n      \"intro\":$(html).find(\".detail-desc\").text(),\n      \"tocUrl\":bookurl,\n      \"wordCount\":\"\",\n      \"type\":2,\n      \"latestChapterTitle\":latestChapterTitle,\n    }\n    return JSON.stringify(book);\n  }\n\n  async function chapter(tocUrl) {\n    var get=await http.Get(tocUrl,JSON.stringify({\n      ...header,\n      \"Referer\":tocUrl,\n    }),true);\n    flutterBridge.text(2,get.data );\n    var chapters=[];\n    var html = $.parseHTML( get.data );\n    $(html).find(\"#detail-list-select\").find(\"li\").each(function(index) {\n      var chapter={\n        \"name\" :$(this).find(\"a\").text().trim(),\n        \"chapterId\":JSON.stringify({\n          \"tocUrl\":tocUrl,\n          \"url\":$(this).find(\"a\").attr('href')\n        }),\n        \"index\" :index,\n        \"isPay\":false,\n        \"isVip\":false,\n        \"isVolume\":false,\n        \"tag\":\"\"\n      };\n      chapters.push(chapter);\n    });\n    return JSON.stringify(chapters);\n  }\n\n  async function content(url) {\n    var d=JSON.parse(url);\n    var get=await http.Get(baseurl+d[\"url\"],JSON.stringify({\n      ...header,\n      \"Referer\":baseurl,\n    }),true);\n    flutterBridge.text(3,get.data );\n    var src=get.data;\n    var chjs = src.match(\/['\"](.*?ch.js\\?v=(\\d+))\/)\n    if ( chjs && chjs[2] != 202208132) {\n        var k=await parseKey(chjs[1] ,d[\"tocUrl\"]);\n        cache.set(\"manwa_aes_key\", k)\n    }\n    var html = $.parseHTML( get.data );\n    var text=\"\";\n    $(html).find(\".content-img\").each(function(index) {\n      var src=$(this).attr('data-r-src')+\",\"+JSON.stringify({\n        \"headers\":{\"origin\":d[\"tocUrl\"],\"Referer\":d[\"url\"]},\n        \"imageDecode\":true\n      });\n      if(src){\n        if(text == \"\"){\n          text=\"<img src=\\\"\"+src+\"\\\" \/>\";\n        }else{\n          text=text+\"\\r\\n\"+\"<img src=\\\"\"+src+\"\\\" \/>\";\n        }\n      }\n    });\n    var key = await  cache.get(\"manwa_aes_key\");\n    if(!key){\n      key = \"my2ecret782ecret\";\n    }\n    flutterBridge.log(\"key=\"+key);\n    return text;\n  }\n\n  async function getfinds() {\n    var sort=[{\n      title: \"发现\",\n      url: \"\",\n      type: 0,\n    }];\n    var str=\"全部::\/booklist\/?page={{page}}\\n\" +\n            \"校园::\/booklist?page={{page}}&tag=校园\\n\" +\n            \"搞笑::\/booklist?page={{page}}&tag=搞笑\\n\" +\n            \"后宫::\/booklist?page={{page}}&tag=后宫\\n\" +\n            \"生活::\/booklist?page={{page}}&tag=生活\\n\" +\n            \"恋爱::\/booklist?page={{page}}&tag=恋爱\\n\" +\n            \"霸总::\/booklist?page={{page}}&tag=霸总\\n\" +\n            \"玄幻::\/booklist?page={{page}}&tag=玄幻\\n\" +\n            \"热血::\/booklist?page={{page}}&tag=热血\\n\" +\n            \"科幻::\/booklist?page={{page}}&tag=科幻\\n\" +\n            \"竞技::\/booklist?page={{page}}&tag=竞技\\n\" +\n            \"灵异::\/booklist?page={{page}}&tag=灵异\\n\" +\n            \"冒险::\/booklist?page={{page}}&tag=冒险\\n\" +\n            \"古风::\/booklist?page={{page}}&tag=古风\\n\" +\n            \"同人::\/booklist?page={{page}}&tag=同人\\n\" +\n            \"真人::\/booklist?page={{page}}&tag=真人\\n\" +\n            \"悬疑::\/booklist?page={{page}}&tag=悬疑\\n\" +\n            \"架空::\/booklist?page={{page}}&tag=架空\\n\" +\n            \"穿越::\/booklist?page={{page}}&tag=穿越\\n\" +\n            \"动作::\/booklist?page={{page}}&tag=动作\\n\" +\n            \"耽美::\/booklist?page={{page}}&tag=耽美\\n\" +\n            \"战争::\/booklist?page={{page}}&tag=战争\\n\" +\n            \"恐怖::\/booklist?page={{page}}&tag=恐怖\\n\" +\n            \"励志::\/booklist?page={{page}}&tag=励志\\n\" +\n            \"修真::\/booklist?page={{page}}&tag=修真\\n\" +\n            \"百合::\/booklist?page={{page}}&tag=百合\\n\" +\n            \"官商::\/booklist?page={{page}}&tag=官商\\n\" +\n            \"重生::\/booklist?page={{page}}&tag=重生\\n\" +\n            \"女主::\/booklist?page={{page}}&tag=女主\"\n    \/\/ 解析分类字符串\n    var categories = str.split('\\n');\n    categories.forEach(function(category) {\n      if (category.trim() !== '') {\n        \/\/ 按::分割获取标题和URL\n        var parts = category.split('::');\n        if (parts.length === 2) {\n          \/\/ 添加到sort数组,去除标题中的多余空格\n          sort.push({\n            title: parts[0].trim(),\n            url: parts[1].trim(),\n            type: 0  \/\/ 保持type为0,与第一个元素一致\n          });\n        }\n      }\n    });\n\n    return JSON.stringify(sort);\n  }\n\n  async function find(url,page) {\n    var u=baseurl+url.replace(\"{{page}}\",page)\n    var get=await http.Get(u,JSON.stringify(header),true);\n    var result=get.data;\n    flutterBridge.text(0,result )\n    var books=[];\n    var html = $.parseHTML( result );\n    $(html).find(\".manga-list\").find(\"li\").each(function(index) {\n      var $element = $(this);\n      var img = $element.find(\"img\").attr('data-original');\n      if(!img) {\n         img= $element.find(\"img\").attr('src');\n      }\n      var book={\n        \"bookUrl\":baseurl+$element.find(\"a\").eq(0).attr('href'),\n        \"name\": $element.find(\"a\").eq(1).text(),\n        \"author\": \"\",\n        \"kind\":  \"\",\n        \"coverUrl\":img.trim()+\",\"+JSON.stringify({\"headers\":header}),\n        \"intro\":$element.find(\".manga-list-2-tip\").text(),\n        \"tocUrl\":baseurl+$element.find(\"a\").eq(0).attr('href'),\n        \"wordCount\":\"\",\n        \"type\":2,\n        \"latestChapterTitle\":\"\",\n      }\n      books.push(book);\n    });\n    return JSON.stringify(books);\n  }\n\n\n  \/\/返回http开头的则任务登录链接会跳webview,其他的会按照json解析显示弹窗\n  async function getloginurl(){\n    return baseurl;\n  }\n\n  \/\/如果登录 url 为非 http 开头的弹窗界面,每次修改完弹窗就会执行此函数\n  async function login(){\n\n  }\n\n  async function pay(bookurl,url){\n\n  }\n\n  \/\/图片解密,image 为加密的图片的base64,执行的js必须是字符串所以这参数只能base64转码\n  \/\/这个函数得返回byteList List<int> ,并且能直接被Uint8List.fromList(byteList)接受\n  async function imagedecrypt(url,image){\n    var key = await  cache.get(\"manwa_aes_key\");\n    if(!key){\n      key = \"my2ecret782ecret\";\n    }\n    return decrypt(image,key,key);\n  }\n\n  async function importScript(url){\n      var c=await cache.get(url);\n      if(c){\n          return c;\n      }\n      var j = await http.Get(url,JSON.stringify(header),true);\n      if(j != null){\n          await cache.set(url,j.data);\n          return j.data;\n      }\n      return \"\"\n  }\n\n  async function parseKey(jsUrl,url) {\n      async function load(t) {\n          for (let o of t) {\n              var j = await http.Get(o,JSON.stringify(),true);\n              if(j != null){\n                  if (!\/exception\/.test(j.data)) return [j.data, o]\n              }\n\n          }\n          throw \"Error: 所有链接下载失败\"\n      }\n      var jsBaseUrls = [\n          \"https:\/\/raw.githubusercontents.com\/Xwite\/decodeObfuscator\/main\/\",\n          \"https:\/\/raw.githubusercontent.com\/Xwite\/decodeObfuscator\/main\/\",\n          \"https:\/\/cdn.jsdelivr.net\/gh\/Xwite\/decodeObfuscator@main\/\"];\n      var urls = [\"plugins\/common.js\",\n          \"plugins\/manwa.js\",\n          \"plugins\/evalPacker.js\",\n          \"tools\/babel_asttool.js\",\n          \"tools\/config.js\",\n          \"tools\/decode.js\",\n          \"tools\/decodeOb.js\",\n          \"tools\/usefulPlugins.js\",\n      ];\n      var jsBaseUrl = await cache.get(\"decodeObfuscator\");\n      if (!jsBaseUrl) {\n          jsBaseUrl = (await load(jsBaseUrls))[1];\n          flutterBridge.showToast(jsBaseUrl)\n          cache.set(\"decodeObfuscator\", jsBaseUrl)\n      }\n      String.prototype.toAbsUrl = function () {\n          return \/^\\.\\\/|^http|^content|^\\\/sdcard|^\\\/storage\/.test(this) ? this : jsBaseUrl.concat(this)\n      };\n      String.prototype.toAbsUrl = function () {\n          return \/^\\.\\\/|^http|^content|^\\\/sdcard|^\\\/storage\/.test(this) ? this : jsBaseUrl.concat(this)\n      }\n      async  function loadJS(urls) {\n          var text=\"\";\n          if(jsBaseUrl){\n              for(var i=0; i<urls.length; i++){\n                  var js=await importScript(urls[i].toAbsUrl())\n                  text=text + \"\\n\" +script(js)\n              }\n          }\n          return text;\n      }\n\n      function script(content) {\n          return '<script>' + content + ';<' + '\/script>';\n      }\n      var alljs=await  loadJS(urls)\n      \/\/html片段\n      var html = `<html><head>${alljs}<\/head><body><\/body><script>\n    function HttpGetText(url){return fetch(url).then(res=>res.text()).catch(err=>alert(err));};\n   HttpGetText(\"${jsUrl}\").then(js=>decode(js,[manwa])).catch(e=>keys=e);`;\n      html=html+ '<' + '\/script><\/html>'\n      var key = JSON.parse(await  flutterBridge.webview( url, \"keys\",html,\"\",\"\"))[0];\n      return key\n  }\n\n  function decrypt(encryptedContent, key, iv) {\n    try {\n      \/\/ 确保key和iv长度符合AES要求\n      const keyHex = CryptoJS.enc.Utf8.parse(key);\n      const ivHex = CryptoJS.enc.Utf8.parse(iv);\n\n      const options = {\n        iv: ivHex,\n        mode: CryptoJS.mode.CBC,\n        padding: CryptoJS.pad.Pkcs7\n      };\n      \/\/ 解密处理 - 确保我们正确处理Base64输入\n      const decrypted = CryptoJS.AES.decrypt(encryptedContent, keyHex, options);\n\n      \/\/ 检查解密是否成功\n      if (!decrypted || decrypted.sigBytes <= 0) {\n        throw new Error(\"Decryption failed: no data returned\");\n      }\n\n      \/\/ 将CryptoJS WordArray转换为Uint8Array\n      const uint8Array = new Uint8Array(decrypted.sigBytes);\n      const words = decrypted.words;\n      let offset = 0;\n\n      for (let i = 0; i < words.length; i++) {\n        const word = words[i];\n        uint8Array[offset++] = (word >> 24) & 0xff;\n        uint8Array[offset++] = (word >> 16) & 0xff;\n        uint8Array[offset++] = (word >> 8) & 0xff;\n        uint8Array[offset++] = word & 0xff;\n      }\n\n      \/\/ 截断到实际长度(因为WordArray是32位对齐的)\n      const truncatedArray = uint8Array.slice(0, decrypted.sigBytes);\n\n      \/\/ 转换为普通JavaScript数组(List<int>格式,用于Flutter)\n      const byteList = Array.from(truncatedArray);\n      \/\/ 返回字节列表,Flutter端可以直接使用Uint8List.fromList(byteList)接收\n      return byteList;\n    } catch (error) {\n      return []; \/\/ 解密失败时返回空数组\n    }\n  }\n\n<\/script>\n\n<\/html>",
    "login": false,
    "lastUpdateTime": "1767342208746"
}
广告