宝华书院

https://www.baohuasy.com

autobcb_admin (12020)3小时前

搜索有验证码 ,只有验证码填写对了才会显示内容
二维码导入(APP尚未完成该功能)
{
    "bookSourceUrl": "https:\/\/www.baohuasy.com",
    "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<script src=\"https:\/\/vc.jd.com\/web\/js\/jquery-3.1.1.min.js\"><\/script>\n<!--如果要引入外部 js 必须在书源代码的上面-->\n<script>\n  var isCookieJar=true;\/\/ 不需要CookieJar请修改此处\n  class FlutterJSBridge {\n    constructor() {\n      this.isReady = false;\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    async log(str) {\n      try {\n        return await window.flutter_inappwebview.callHandler('log',str);\n      } catch (error) {\n        return  false;\n      }\n    }\n\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    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    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    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     * 使用webView获取跳转url\n     * overrideUrlRegex 为正则表达式\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    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    async utf8ToGbkUrlEncoded(str) {\n      try {\n        return await window.flutter_inappwebview.callHandler('utf8ToGbkUrlEncoded',str);\n      } catch (error) {\n        return  \"\";\n      }\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  }\n\n  \/\/webview请勿使用\n  class Http {\n    constructor() {}\n\n    \/\/以下提交的url,headers,body 都必须为字符串,headers必须为json字符串\n\n    \/\/当followRedirects 为 false 时不处理重定向,当为 true 时会自动处理重定向 ,如不明白用途直接用 true 最佳\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    \/\/注意post 请求是务必在 header 中带上content-type\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  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    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  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\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<script>\n  const flutterBridge = new FlutterJSBridge();\n  const cache = new Cache();\n  const http = new Http();\n  const cookie = new Cookie();\n  var baseurl=\"https:\/\/www.baohuasy.com\"\n  var header={ \"User-Agent\": \"Mozilla\/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit\/537.36 (KHTML, like Gecko) Chrome\/142.0.0.0 Safari\/537.36 Edg\/142.0.0.0\" };\n  async function search(key,page) {\n    if(page > 1){\n      return  \"[]\";\n    }\n    cookie.remove(baseurl)\n    var get=await http.Get(baseurl,JSON.stringify(header),true);\n    var s=get.data\n    var act=s.match(\/\"act\".*?\"(.{16})\"\/)[1]\n    var sub=s.match(\/name=\"submit\".*?value=\"(.*?)\"\/)[1]\n    var url=baseurl+\"\/sscc\/\"\n    var body=\"act=\"+act+\"&q=\"+(await  flutterBridge.utf8ToGbkUrlEncoded(key))+\"&submit=\"+(await  flutterBridge.utf8ToGbkUrlEncoded(sub));\n    var myheader={\n      ...header,\n    }\n    get=await http.Post(url,JSON.stringify(myheader),body,\"application\/x-www-form-urlencoded\",false);\n    var burl=baseurl+\"\/sscc\/\"+get.headers[\"location\"]\n    get=await http.Post(url,JSON.stringify(myheader),body,\"application\/x-www-form-urlencoded\",true);\n    var result=get.data\n    var c2=result.match(\/c2=\"(.*?)\"\/)[1]\n    var u2=result.match(\/src=\"(.*?)\"\/)[1]\n    var origin=baseurl.match(\/[^.]+[^\/]+\/)[0]\n    var str=(await http.Get(origin+u2,JSON.stringify(myheader),false)).data.match(\/function.*\\(\\)\\}\/)[0];\n    eval(str);\n    temp=ajax(c2)\n    await http.Get(origin+temp,JSON.stringify(myheader),false)\n    result=(await http.Get(burl,JSON.stringify(myheader),false)).data;\n\n    var actyzm=result.match(\/actyzm\" value=\"([^\"]+)\"\/)[1];\n    var button=result.match(\/button\" value=\"([^\"]+)\"\/)[1];\n    url=burl;\n    var code=url.replace(\/\\\/sscc.*\/,'')+\"\/member\/getcode.asp\";\n    var yzco=await cache.get(\"cookie\");\n    async function succes() {\n      var myheader={\n        ...header,\n        \"Referer\":burl,\n      }\n      var yzm =await flutterBridge.getVerificationCode(code, JSON.stringify(myheader));\n      var body=\"actyzm=\"+actyzm+\"&yzm=\"+yzm+\"&button=\"+(await  flutterBridge.utf8ToGbkUrlEncoded(button));\n      var hm = (await http.Post(burl, JSON.stringify(myheader),body,\"application\/x-www-form-urlencoded\", false)).data;\n      var co = await cookie.getCookie(url, \"g3jy9sqo0ws\");\n      await cache.set(\"cookie\", yzm + ',g3jy9sqo0ws=' + co)\n      return hm;\n    }\n    if(yzco && yzco!=''){\n      var v=yzco.split(',');\n      var body=\"actyzm=\"+actyzm+\"&yzm=\"+v[0]+\"&button=\"+(await  flutterBridge.utf8ToGbkUrlEncoded(button));\n      var myheader={\n        ...header,\n        \"Referer\":burl,\n        \"Cookie\":v[1]\n      }\n      result=(await http.Post(burl, JSON.stringify(myheader),body,\"application\/x-www-form-urlencoded\", false)).data;\n      if(\/请输入验证码\/.test(result)){\n        flutterBridge.showToast(\"  !验证码过期或有误,重新获取  !\")\n        result=await  succes();\n      }\n    }else{\n      result=await succes();\n    }\n    flutterBridge.text(0,result)\n    var books=[];\n    var html = $.parseHTML( result );\n    $(html).find(\".B\").each(function(index) {\n      try{\n        var $element = $(this);\n        var author =$element.find(\"dd\").eq(1).find(\"span\").eq(0).text();\n        var kind=\"\";\n        var s=author.split(\":\");\n        if(s.length > 1){\n          author=s[1].trim()\n        }\n        if($element.find(\"dd\").eq(1).find(\"span\").length > 1){\n          kind=$element.find(\"dd\").eq(1).find(\"span\").eq(1).text();\n          s=kind.split(\":\");\n          if(s.length > 1){\n            kind=s[1].trim()\n          }\n        }\n        var img=\"\";\n        var src = $element.find(\"img\").attr('src');\n        var dataSrc = $element.find(\"img\").attr('data-src');\n        if(dataSrc){\n          img=baseurl+dataSrc;\n        }else{\n          img=baseurl+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\":author,\n          \"kind\":kind,\n          \"coverUrl\":img,\n          \"intro\":$element.find(\".d2\").text(),\n          \"tocUrl\":baseurl+$element.find(\"a\").eq(0).attr('href'),\n          \"wordCount\":\"\",\n          \"type\":0,\n          \"latestChapterTitle\":$element.find(\".p4\").find(\"a\").text(),\n        }\n        books.push(book);\n      }catch(e){\n\n      }\n    });\n\n    return JSON.stringify(books);\n  }\n\n  async function info(bookurl) {\n    var get=await http.Get(bookurl,JSON.stringify(header),true);\n    flutterBridge.text(1,get.data )\n    var html = $.parseHTML( get.data );\n    var info=$(html).find(\"#info\")\n    var author =info.find(\"p\").eq(0).text();\n    var kind= info.find(\"p\").eq(1).find(\"span\").eq(0).text();\n    var s=author.split(\":\");\n    if(s.length > 1){\n      author=s[1].trim()\n    }\n    s=kind.split(\":\");\n    if(s.length > 1){\n      kind=s[1].trim()\n    }\n    var img=\"\";\n    var src = $(html).find(\".Dimg\").find(\"img\").attr('src');\n    img=baseurl+src;\n    var book={\n      \"bookUrl\":bookurl,\n      \"name\":info.find(\"h1\").text(),\n      \"author\":author,\n      \"kind\":kind,\n      \"coverUrl\":img,\n      \"intro\":$(html).find(\"#intro\").text(),\n      \"tocUrl\":bookurl,\n      \"wordCount\":\"\",\n      \"type\":0,\n      \"latestChapterTitle\":info.find(\"p\").eq(3).find(\"a\").text(),\n    }\n    return JSON.stringify(book);\n  }\n\n  async function chapter(tocUrl) {\n    try {\n      var get = await http.Get(tocUrl, JSON.stringify(header), true);\n      flutterBridge.text(2,get.data )\n      \/\/ 检查返回数据是否有效\n      if (!get || !get.data) {\n        flutterBridge.log(\"获取数据失败:无效的响应数据\");\n        return \"[]\";\n      }\n      var chapters=[];\n      var html = $.parseHTML(get.data);\n      var $htmlObj = $(html);\n      \/\/ 检查是否找到dl元素\n      var $dl = $htmlObj.find(\"dl\");\n      if ($dl.length > 0) {\n        \/\/ 获取第一个dl元素\n        var $firstDl = $dl.eq(0);\n        var $children = $firstDl.children();\n        var dt=0;\n        var i=0;\n        \/\/ 遍历子元素\n        $children.each(function(index) {\n          var $child = $(this);\n          if($child.prop(\"tagName\").toLowerCase() == \"dt\".toLowerCase()){\n            dt++;\n          }else if(dt >= 2){\n            var chapter={\n              \"name\" :$(this).text(),\n              \"chapterId\":\"https:\/\/m.baohuasy.com\/\"+$(this).find(\"a\").attr('href'),\n              \"index\" :i,\n              \"isPay\":false,\n              \"isVip\":false,\n              \"isVolume\":false,\n              \"tag\":\"\"\n            };\n            i++;\n            chapters.push(chapter);\n          }\n        });\n      } else {\n        flutterBridge.log(\"未找到dl元素\");\n      }\n    } catch (error) {\n      flutterBridge.log(\"处理章节内容时出错:\"+error.message);\n    }\n    return JSON.stringify(chapters);\n  }\n\n  async function content(url) {\n    var first=await getContent(url)\n    flutterBridge.text(3,first )\n    var result=\"\"\n    \n    \/\/ 使用并发安全的解析函数\n    var $tempContainer = parseHTMLSafely(removeHTMLTags(first));\n    var hrefs=[];\n    $tempContainer.find(\"#PageSet\").find(\"a\").each(function(index) {\n      var $child = $(this);\n      var href=$child.attr('href')\n      if(hrefs.indexOf(href)==-1){\n        hrefs.push(href);\n      }\n    })\n    result=getContentString($tempContainer);\n    removeHTMLSafely($tempContainer)\n    var s=url.split(\"\/\/baoh\")\n    s=(s[1]).split(\"\/\")\n    for(var i=0;i<hrefs.length;i++){\n      var url=\"https:\/\/m.baohuasy.com\/\/baoh\/\"+s[1]+\"\/\"+hrefs[i];\n      var re=await http.Get(url, JSON.stringify(header), true);\n      var $tempContainer = parseHTMLSafely(removeHTMLTags(re.data));\n      var r=getContentString($tempContainer);\n      result=result+r;\n      removeHTMLSafely($tempContainer)\n    }\n    result=result.replaceAll(\"<\/p><p>\",\"\\r\\n\").replaceAll(\"<br>\",\"\\r\\n\").replaceAll(\"<p>\",\"\").replaceAll(\"<\/p>\",\"\")\n    result=result.replace(\/(##\\s+\"\\n|\\s+本章(没|未)完,.*|(\\.\\n)?.*看完记得收藏.*|\\s+\\\/\\d+\\\/.*|\\s+。:.*|\\s+:。.*|.*语录书院.*|4126.*|正在手打中.*|.*书架书签更方便.*|.*收藏此页.*|.*报错.*|.*耐心等待.*|温馨提示.*(123读书网|来看小说网|宝华书院).*|3920(\\d+)\\.\\.$|^…\\.\\.$)\/gm, '');\n    return result;\n  }\n\n  async function getfinds() {\n    var  sort=[{\n      title: \"发现\",\n      url: \"\",\n      type: 0,\n    }];\n    var get=await http.Get(baseurl,JSON.stringify(header),true);\n    var $tempContainer = parseHTMLSafely(removeHTMLTags(get.data ));\n    $tempContainer.find(\".nav\").find(\"a\").each(function(index) {\n      if(index != 0){\n        sort.push({\n          title: $(this).text(),\n          url: baseurl+$(this).attr('href'),\n          type: 0,\n        });\n      }\n    });\n    removeHTMLSafely($tempContainer)\n    return JSON.stringify(sort);\n  }\n\n  async function find(url,page) {\n    if(page > 1){\n      return  \"[]\";\n    }\n    var get=await http.Get(url,JSON.stringify(header),true);\n    flutterBridge.text(0,get.data )\n    var books=[];\n    var html = $.parseHTML( get.data );\n    $(html).find(\".B\").each(function(index) {\n      try{\n        var $element = $(this);\n        var author =$element.find(\"dd\").eq(1).find(\"span\").eq(0).text();\n        var kind=\"\";\n        var s=author.split(\":\");\n        if(s.length > 1){\n          author=s[1].trim()\n        }\n        if($element.find(\"dd\").eq(1).find(\"span\").length > 1){\n          kind=$element.find(\"dd\").eq(1).find(\"span\").eq(1).text();\n          s=kind.split(\":\");\n          if(s.length > 1){\n            kind=s[1].trim()\n          }\n        }\n        var img=\"\";\n        var src = $element.find(\"img\").attr('src');\n        var dataSrc = $element.find(\"img\").attr('data-src');\n        if(dataSrc){\n          img=baseurl+dataSrc;\n        }else{\n          img=baseurl+src;\n        }\n        var book={\n          \"bookUrl\":baseurl+$element.find(\"a\").eq(0).attr('href'),\n          \"name\":$element.find(\"a\").text(),\n          \"author\":author,\n          \"kind\":kind,\n          \"coverUrl\":img,\n          \"intro\":$element.find(\".d2\").text(),\n          \"tocUrl\":baseurl+$element.find(\"a\").eq(0).attr('href'),\n          \"wordCount\":\"\",\n          \"type\":0,\n          \"latestChapterTitle\":$element.find(\".p4\").find(\"a\").text(),\n        }\n        books.push(book);\n      }catch(e){\n\n      }\n    });\n\n    return JSON.stringify(books);\n  }\n\n  function getContentString(tempContainer) {\n    var result=\"\"\n    tempContainer.find(\".TxtContent\").each(function(index) {\n      var $child = $(this);\n      if($child.prop(\"tagName\").toLowerCase() == \"img\".toLowerCase()){\n        result=result+$child.html()+\"\\r\\n\";\n      }else{\n        var txt=$child.html()\n        result=result+txt;\n      }\n    })\n    return result\n  }\n\n  async function getContent(url) {\n    cookie.remove(url)\n    var get = await http.Get(url, JSON.stringify(header), true);\n    var result=get.data;\n    var c2=result.match(\/c2=\"(.*?)\"\/)[1]\n    var u2=result.match(\/src=\"(.*?)\"\/)[1]\n    var origin=baseurl.match(\/[^.]+[^\/]+\/)[0]\n    get=await http.Get(origin+u2,JSON.stringify(header),true);\n    var str=get.data.match(\/function.*\\(\\)\\}\/)[0]\n    eval(str);\n    var temp=ajax(c2)\n    await http.Get(origin+temp,JSON.stringify(header),false)\n    result= (await http.Get(url, JSON.stringify(header), true)).data;\n    return result;\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<\/script>\n<\/html>",
    "login": false,
    "lastUpdateTime": "1767339591323"
}
广告