From a9ac16fecc0cf9bc66dfaefe4e9b35fa3c722812 Mon Sep 17 00:00:00 2001
From: king <18310653075@163.com>
Date: 星期二, 10 十一月 2020 16:58:43 +0800
Subject: [PATCH] 2020-11-10

---
 src/api/index.js |  235 +++++++++++++++++++++++-----------------------------------
 1 files changed, 93 insertions(+), 142 deletions(-)

diff --git a/src/api/index.js b/src/api/index.js
index ac8f0f2..6821ef2 100644
--- a/src/api/index.js
+++ b/src/api/index.js
@@ -59,6 +59,11 @@
 
 const setCurrentUrl = () => {
   if (!!(window.history && window.history.pushState)) {
+    if (window.location.href.indexOf('paramsmain') > -1) {
+      let _href = window.location.href.split('#')
+      localStorage.setItem(_href[0] + 'paramsmain', _href[1])
+    }
+
     sessionStorage.clear()
     window.history.replaceState(null, null, window.location.href.split('#')[0] + '#/login')
     window.location.reload()
@@ -69,7 +74,12 @@
 
 axios.interceptors.response.use((response) => {
   if (response.data.ErrCode === 'LoginError') {
-    setCurrentUrl()
+    if (window.debugger === true) {
+      response.data.ErrCode = 'E'
+      return Promise.resolve(response.data)
+    } else {
+      setCurrentUrl()
+    }
   } else {
     return Promise.resolve(response.data)
   }
@@ -114,20 +124,7 @@
     param.userid = param.userid || sessionStorage.getItem('UserID') || ''
     param.LoginUID = param.LoginUID || sessionStorage.getItem('LoginUID') || ''
 
-    param.nonc = Utils.getuuid()
-    
-    let keys = Object.keys(param).sort()
-    let values = ''
-    keys.forEach(key => {
-      if (key === 'rduri' || key === 't') return
-      if (typeof(param[key]) === 'object') {
-        values += key + JSON.stringify(param[key])
-      } else {
-        values += key + param[key]
-      }
-    })
-    param.sign  = md5(values)
-    param.t = new Date().getTime()
+    param = this.encryptParam(param)
 
     return axios({
       url: '/webapi/dostar',
@@ -148,7 +145,7 @@
 
     let param = {
       func: 's_visitor_login',
-      timestamp: moment().format('YYYY-MM-DD HH:mm:ss') + '.000', 
+      timestamp: moment().format('YYYY-MM-DD HH:mm:ss'), 
       SessionUid: _SessionUid,
       TypeCharOne: 'pc'
     }
@@ -282,20 +279,7 @@
         param.rduri = window.GLOB.mainSystemApi
       }
   
-      param.nonc = Utils.getuuid()
-      
-      let keys = Object.keys(param).sort()
-      let values = ''
-      keys.forEach(key => {
-        if (key === 'rduri' || key === 't') return
-        if (typeof(param[key]) === 'object') {
-          values += key + JSON.stringify(param[key])
-        } else {
-          values += key + param[key]
-        }
-      })
-      param.sign  = md5(values)
-      param.t = new Date().getTime()
+      param = this.encryptParam(param)
   
       return new Promise((resolve, reject) => {
         axios({
@@ -407,25 +391,59 @@
       param.LoginUID = sessionStorage.getItem('LoginUID') || ''
     }
 
-    param.nonc = Utils.getuuid()
-    
-    let keys = Object.keys(param).sort()
-    let values = ''
-    keys.forEach(key => {
-      if (key === 'rduri' || key === 't') return
-      if (typeof(param[key]) === 'object') {
-        values += key + JSON.stringify(param[key])
-      } else {
-        values += key + param[key]
-      }
-    })
-    param.sign  = md5(values)
-    param.t = new Date().getTime()
+    param = this.encryptParam(param)
 
     return axios({
       url: `/webapi/dostars${param.func ? '/' + param.func : ''}`,
       data: param
     })
+  }
+
+  /**
+   * @description 鑾峰彇浜戠閰嶇疆锛屽苟缂撳瓨淇℃伅
+   */
+  getCloudCacheConfig (param) {
+    param.lang = localStorage.getItem('lang') || ''
+    param.appkey = window.GLOB.appkey || ''
+    param.SessionUid = localStorage.getItem('SessionUid') || ''
+
+    if (sessionStorage.getItem('CloudUserID') && options.cloudServiceApi) { // 瀛樺湪浜戠鐧诲綍淇℃伅锛屼笖瀛樺湪浜戠鍦板潃
+      param.rduri = options.cloudServiceApi
+      param.userid = sessionStorage.getItem('CloudUserID')
+      param.LoginUID = sessionStorage.getItem('CloudLoginUID') || ''
+    } else if (window.GLOB.mainSystemApi) {
+      param.rduri = window.GLOB.mainSystemApi
+      param.userid = sessionStorage.getItem('UserID')
+      param.LoginUID = sessionStorage.getItem('LoginUID') || ''
+    } else {
+      param.userid = sessionStorage.getItem('UserID')
+      param.LoginUID = sessionStorage.getItem('LoginUID') || ''
+    }
+
+    let _param = JSON.parse(JSON.stringify(param)) // 缂撳瓨鏍¢獙锛屽幓闄ゆ椂闂村拰鍔犲瘑瀛楃
+    delete _param.timestamp
+    delete _param.secretkey
+    delete _param.open_key
+    _param = JSON.stringify(_param)
+    _param  = md5(_param)
+    
+    if (window.GLOB.CacheMap.has(_param)) {
+      return Promise.resolve(window.GLOB.CacheMap.get(_param))
+    } else {
+      param = this.encryptParam(param)
+
+      return new Promise(resolve => {
+        axios({
+          url: `/webapi/dostars${param.func ? '/' + param.func : ''}`,
+          data: param
+        }).then(res => {
+          if (res.status) {
+            window.GLOB.CacheMap.set(_param, res)
+          }
+          resolve(res)
+        })
+      })
+    }
   }
 
   /**
@@ -446,20 +464,7 @@
       param.rduri = window.GLOB.mainSystemApi
     }
 
-    param.nonc = Utils.getuuid()
-    
-    let keys = Object.keys(param).sort()
-    let values = ''
-    keys.forEach(key => {
-      if (key === 'rduri' || key === 't') return
-      if (typeof(param[key]) === 'object') {
-        values += key + JSON.stringify(param[key])
-      } else {
-        values += key + param[key]
-      }
-    })
-    param.sign  = md5(values)
-    param.t = new Date().getTime()
+    param = this.encryptParam(param)
 
     return axios({
       url: `/webapi/dostars${param.func ? '/' + param.func : ''}`,
@@ -477,20 +482,7 @@
     param.LoginUID = sessionStorage.getItem('LoginUID') || ''
     param.appkey = window.GLOB.appkey || ''
 
-    param.nonc = Utils.getuuid()
-    
-    let keys = Object.keys(param).sort()
-    let values = ''
-    keys.forEach(key => {
-      if (key === 'rduri' || key === 't') return
-      if (typeof(param[key]) === 'object') {
-        values += key + JSON.stringify(param[key])
-      } else {
-        values += key + param[key]
-      }
-    })
-    param.sign  = md5(values)
-    param.t = new Date().getTime()
+    param = this.encryptParam(param)
 
     return axios({
       url: `/webapi/dostars${param.func ? '/' + param.func : ''}`,
@@ -527,20 +519,7 @@
     _param  = md5(_param)
     
     if (mkDataBase && storUsable) {
-      param.nonc = Utils.getuuid()
-      
-      let keys = Object.keys(param).sort()
-      let values = ''
-      keys.forEach(key => {
-        if (key === 'rduri' || key === 't') return
-        if (typeof(param[key]) === 'object') {
-          values += key + JSON.stringify(param[key])
-        } else {
-          values += key + param[key]
-        }
-      })
-      param.sign  = md5(values)
-      param.t = new Date().getTime()
+      param = this.encryptParam(param)
 
       return new Promise(resolve => {
         mkDataBase.transaction(tx => {
@@ -587,20 +566,7 @@
     } else if (window.GLOB.CacheMap.has(_param)) {
       return Promise.resolve(window.GLOB.CacheMap.get(_param))
     } else {
-      param.nonc = Utils.getuuid()
-      
-      let keys = Object.keys(param).sort()
-      let values = ''
-      keys.forEach(key => {
-        if (key === 'rduri' || key === 't') return
-        if (typeof(param[key]) === 'object') {
-          values += key + JSON.stringify(param[key])
-        } else {
-          values += key + param[key]
-        }
-      })
-      param.sign  = md5(values)
-      param.t = new Date().getTime()
+      param = this.encryptParam(param)
 
       return new Promise(resolve => {
         axios({
@@ -627,6 +593,30 @@
   }
 
   /**
+   * @description dostars 鍙傛暟鍔犲瘑
+   */
+  encryptParam (param) {
+    param.nonc = Utils.getuuid()
+      
+    let keys = Object.keys(param).sort()
+    let values = ''
+    keys.forEach(key => {
+      if (key === 'rduri' || key === 't') return
+      if (param[key] === undefined) {
+        delete param[key]
+      } else if (typeof(param[key]) === 'object') {
+        values += key + JSON.stringify(param[key])
+      } else {
+        values += key + param[key]
+      }
+    })
+    param.sign = md5(values)
+    param.t = new Date().getTime()
+
+    return param
+  }
+
+  /**
    * @description 鑾峰彇绯荤粺閰嶇疆锛屼紭鍏堜粠缂撳瓨涓彇鍊硷紝澧炲姞appkey
    * @param {Object}  param   璇锋眰鍙傛暟
    * @param {Boolean} SSO     鏄惁涓哄崟鐐圭櫥褰曞湴鍧�
@@ -648,20 +638,7 @@
     if (window.GLOB.CacheMap.has(_param)) {
       return Promise.resolve(window.GLOB.CacheMap.get(_param))
     } else {
-      param.nonc = Utils.getuuid()
-      
-      let keys = Object.keys(param).sort()
-      let values = ''
-      keys.forEach(key => {
-        if (key === 'rduri' || key === 't') return
-        if (typeof(param[key]) === 'object') {
-          values += key + JSON.stringify(param[key])
-        } else {
-          values += key + param[key]
-        }
-      })
-      param.sign = md5(values)
-      param.t = new Date().getTime()
+      param = this.encryptParam(param)
 
       return new Promise(resolve => {
         axios({
@@ -692,20 +669,7 @@
       param.LoginUID = sessionStorage.getItem('CloudLoginUID') || ''
     }
 
-    param.nonc = Utils.getuuid()
-    
-    let keys = Object.keys(param).sort()
-    let values = ''
-    keys.forEach(key => {
-      if (key === 'rduri' || key === 't') return
-      if (typeof(param[key]) === 'object') {
-        values += key + JSON.stringify(param[key])
-      } else {
-        values += key + param[key]
-      }
-    })
-    param.sign  = md5(values)
-    param.t = new Date().getTime()
+    param = this.encryptParam(param)
 
     return axios({
       url: `/webapi/dostars${param.func ? '/' + param.func : ''}`,
@@ -791,20 +755,7 @@
       param.LoginUID = sessionStorage.getItem('LoginUID') || ''
     }
 
-    param.nonc = Utils.getuuid()
-    
-    let keys = Object.keys(param).sort()
-    let values = ''
-    keys.forEach(key => {
-      if (key === 'rduri' || key === 't') return
-      if (typeof(param[key]) === 'object') {
-        values += key + JSON.stringify(param[key])
-      } else {
-        values += key + param[key]
-      }
-    })
-    param.sign  = md5(values)
-    param.t = new Date().getTime()
+    param = this.encryptParam(param)
 
     if (param.rduri) {
       param.rduri = param.rduri.replace(/webapi(.*)$/, 'webapi/SaveBase64Image')

--
Gitblit v1.8.0