From 8ee79710640b73f616d268460adb91b58d1df521 Mon Sep 17 00:00:00 2001
From: Tevin <tingquanren@163.com>
Date: Thu, 02 Dec 2021 16:39:36 +0800
Subject: [PATCH] 微调底层文件结构,微调测试环境判断

---
 bases/Fetcher.js |   30 ++++++++++++++++++++++++------
 1 files changed, 24 insertions(+), 6 deletions(-)

diff --git a/bases/Fetcher.js b/bases/Fetcher.js
index d934518..0d123b0 100644
--- a/bases/Fetcher.js
+++ b/bases/Fetcher.js
@@ -187,6 +187,7 @@
         });
     }
 
+    // 小程序中,保存 cookies
     _saveCookies(cookies) {
         const localCookies = JSON.parse(Taro.getStorageSync('cookies') || '{}');
         cookies.forEach(cookie => {
@@ -196,6 +197,7 @@
         Taro.setStorageSync('cookies', JSON.stringify(localCookies));
     }
 
+    // 小程序中,获取 cookies
     _getCookies() {
         const localCookies = JSON.parse(Taro.getStorageSync('cookies') || '{}');
         const cookiesArr = [];
@@ -386,9 +388,9 @@
             if (process.env.TARO_ENV === 'weapp') {
                 Taro.navigateTo({ url: '/pages/home/index/index?mode=login' });
             }
-            // 在App中,直接跳转登陆页
+            // 在App中,跳转到首页取消登陆
             if (project.appHybrid) {
-                Taro.reLaunch({ url: '/pages/home/login/login' });
+                Taro.navigateTo({ url: '/pages/home/index/index?mode=logout' });
             }
             return null;
         } else {
@@ -576,8 +578,22 @@
     static inDevMod = (() => {
         // 网页
         if (process.env.TARO_ENV === 'h5') {
-            // 当没有 url 指定时,只有内网 ip 和 33**/35** 的端口号,视为本地开发模式
-            return /^(192|127|localhost).*?:3[35]\d{2}$/i.test(window.location.host);
+            // http协议访问
+            if (window.location.protocol.indexOf('http') > 0) {
+                // 当内网 ip 且使用 33**/35** 的端口号时,视为本地开发模式
+                return /^(192|127|localhost).*?:3[35]\d{2}$/i.test(window.location.host);
+            }
+            // 非http协议访问
+            else {
+                // 开发编译
+                if (process.env.NODE_ENV === 'development') {
+                    return true;
+                }
+                // 生产编译
+                else if (process.env.NODE_ENV === 'production') {
+                    return false;
+                }
+            }
         }
         // 小程序
         else if (process.env.TARO_ENV === 'weapp') {
@@ -602,9 +618,11 @@
             // 如果网址参数有指定服务器
             const server = Tools.getUrlParam('server');
             if (server) {
-                // 如果是完整网址,直接使用地址
+                // 如果是完整网址,使用网址对应的域名
                 if (server.indexOf('http') >= 0) {
-                    return server;
+                    const portal = server.split('//')[0];
+                    const domain = server.split('//')[1].split('/')[0];
+                    return portal + '//' + domain;
                 }
                 // 如果有匹配服务器,使用指定的服务器地址
                 if (typeof project.host.hosts[server] !== 'undefined') {

--
Gitblit v1.9.1