king
2025-05-23 24842b40de5cd60700bf69dfd38a0332f5431e36
src/api/index.js
@@ -48,10 +48,12 @@
        okText: '知道了',
        onOk: () => {
          window.GLOB.$error = false
          sessionStorage.clear()
          if (!!(window.history && window.history.pushState)) {
            window.history.replaceState(null, null, window.location.href.split('#')[0] + '#/login')
            window.location.reload()
          if (!/#\/login/.test(window.location.href)) {
            sessionStorage.clear()
            if (!!(window.history && window.history.pushState)) {
              window.history.replaceState(null, null, window.location.href.split('#')[0] + '#/login')
              window.location.reload()
            }
          }
        }
      })
@@ -59,6 +61,15 @@
    return Promise.reject(response.data)
  } else {
    if (response.data.ErrCode === 'E') {
      if (/死锁|尚未从池中获取连接/.test(response.data.message)) {
        response.data.message = (window.GLOB.dict['server_busy'] || '服务器繁忙,请稍后重试!') + (/死锁/.test(response.data.message) ? '01' : '02')
        response.data.ErrMesg = response.data.message
      } else if (/无法打开登录所请求的数据库|在与\s*SQL\s+Server\s*建立连接时出现/.test(response.data.message)) {
        response.data.message = '服务器链接不可用,请关闭浏览器重新打开!'
        response.data.ErrMesg = response.data.message
      }
    }
    if (response.config.requestId) {
      response.data.$requestId = response.config.requestId
    }
@@ -67,7 +78,15 @@
}, (error) => {
  let response = error.response || ''
  if (response && response.status) {
  if (!response) {
    notification.error({
      className: 'notification-custom-error',
      bottom: 0,
      message: error.message.includes('Network Error') && sessionStorage.getItem('lang') === 'zh-CN' ? '网络连接失败!' : error.message,
      placement: 'bottomRight',
      duration: 15
    })
  } else if (response && response.status) {
    notification.error({
      className: 'notification-custom-error',
      bottom: 0,
@@ -121,6 +140,17 @@
      url: `/webapi/dostar${param.func ? '/' + param.func : ''}`,
      method: 'post',
      data: JSON.stringify(param)
    })
  }
  /**
   * @description 老系统登录
   */
  loginAndRedirect (param) {
    return axios({
      url: document.location.origin + '/zh-CN/Home/LoginAndRedirect',
      method: 'post',
      data: qs.stringify(param)
    })
  }
@@ -214,6 +244,9 @@
      } else {
        param.linkurl = window.GLOB.linkurl
      }
    } else if (binding_type === 'cloud') { // 登录云端
      delete param.rduri
      url = window.atob('aHR0cHM6Ly9jbG91$mkZC5tazloLmNu'.replace('$mk', '')) + '/webapi/dologon/s_visitor_login'
    }
    
    param.LText = md5(window.btoa(_SessionUid + param.timestamp + (param.linkurl || '')))
@@ -247,7 +280,8 @@
      login_id_address: sessionStorage.getItem('ipAddress') || '',
      kei_id: window.btoa(window.encodeURIComponent(window.GLOB.host)),
      device_id: localStorage.getItem('SessionUid'),
      appkey: window.GLOB.appkey || ''
      appkey: window.GLOB.appkey || '',
      lang: sessionStorage.getItem('lang') || ''
    }
    let url = '/webapi/dologon'
@@ -285,7 +319,8 @@
      kei_id: window.btoa(window.encodeURIComponent(window.GLOB.host)),
      device_id: localStorage.getItem('SessionUid'),
      timestamp: moment().add(shim, 'seconds').format('YYYY-MM-DD HH:mm:ss'),
      appkey: window.GLOB.appkey || ''
      appkey: window.GLOB.appkey || '',
      lang: sessionStorage.getItem('lang') || ''
    }
    
    // Type: 'S' 时
@@ -303,6 +338,11 @@
    
    // Type: 'X' 时
    // param.Password = Utils.formatOptions(password)
    // positecgroup
    if (window.GLOB.appkey === '202011021844144334E823A3011414082AD77') {
      param.svccode = 'oms'
    }
    let url = '/webapi/dologon'
@@ -351,6 +391,36 @@
          resolve({data: null, valid: false})
        }
      })
    })
  }
  /**
   * @description 登录二次验证 // positecgroup
   */
  verifycode (verify) {
    let param = {
      certificate: 'certificate',
      captcha: verify.code,
      token: verify.token,
      ati: verify.ati,
      vid: verify.vid,
      uid: verify.uid,
      shopId: verify.shopId,
      loginId: verify.loginId,
      phone: verify.phone,
      sellerNick: verify.sellerNick,
      isRisk: verify.isRisk,
      requestId: verify.requestId,
      riskNum: verify.riskNum,
      username: verify.username
    }
    let url = '/webapi/dologon'
    return axios({
      url,
      method: 'post',
      data: param
    })
  }
@@ -733,7 +803,7 @@
    }
    let url = '/webapi/dostars'
    if (param.rduri && !window.GLOB.transfer) {
    if (param.rduri && !window.GLOB.transfer) { // positecgroup
      url = param.rduri
      delete param.rduri
    }
@@ -1023,6 +1093,14 @@
      param.data_md5 = param.data_md5 || ''
      param.time_limit = param.time_limit || 0
      param.data.forEach(item => {
        item.exps.forEach(cell => {
          if (typeof(cell.value) === 'number') {
            cell.value = cell.value + ''
          }
        })
      })
      param = this.encryptParam(param)
      return new Promise((resolve) => {
@@ -1047,8 +1125,9 @@
              res.ErrCode = '-2'
              MKEmitter.emit('reloadTabs')
            } else if (res.message === 'permission deny') {
              res.message = window.GLOB.dict['permission_deny'] || '无当前菜单或按钮的访问权限,请联系管理员!'
              res.ErrMesg = window.GLOB.dict['permission_deny'] || '无当前菜单或按钮的访问权限,请联系管理员!'
              let isBtn = url.indexOf('s_TableData_InUpDe') > -1
              res.message = window.GLOB.dict['permission_deny'] || `无当前${isBtn ? '按钮' : '菜单'}的访问权限,请联系管理员!`
              res.ErrMesg = res.message
            }
          }
          resolve(res)