123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131 |
- import store from '@/store'
- import config from '@/config'
- import {
- AESDecrypt,
- AESEncypt,
- RSAEncrypt,
- RSADecrypt,
- createKey
- } from '@/utils/dataParams.js'
- import {
- getToken
- } from '@/utils/auth'
- import errorCode from '@/utils/errorCode'
- import {
- toast,
- showConfirm,
- tansParams
- } from '@/utils/common'
- let timeout = 10000
- const serverAddress = uni.getStorageSync('serverAddress')
- const baseUrlIp = serverAddress ? serverAddress : config.baseUrl
- const baseUrl = baseUrlIp + '/projects/outApi'
- const request = config => {
- // console.log(config.data || config.params)
- // 是否需要设置 token
- const isToken = (config.headers || {}).isToken === false
- config.header = config.header || {}
- if (getToken() && !isToken) {
- config.header['token'] = getToken()
- }
- // get请求映射params参数
- let urlOrginal = "" + config.url;
- if (config.params) {
- let url = config.url + '?' + tansParams(config.params)
- url = url.slice(0, -1)
- config.url = url
- }
- // console.log(config.url)
- // console.log(config.params || config.data)
- let pwdConfig = {}
- // 如果是对象形式传递的params
- if (config.formParams) {
- const encryptKey = createKey()
- pwdConfig.encryptKey = encryptKey
- for (var i in config.formParams) {
- config.formParams[i] = AESEncypt(config.formParams[i], encryptKey).data
- }
- config.header['GoWork'] = RSAEncrypt(encryptKey)
- config.data = config.formParams
- }
- if (config.data) {
- pwdConfig = AESEncypt(JSON.stringify(config.data))
- config.header['GoWork'] = RSAEncrypt(pwdConfig.encryptKey)
- config.data = pwdConfig.data;
- }
- if (!pwdConfig.encryptKey) {
- const encryptKey = createKey()
- pwdConfig.encryptKey = encryptKey
- config.header['GoWork'] = RSAEncrypt(encryptKey)
- }
- // console.log("params", config.params)
- // console.log("data", config.data)
- return new Promise((resolve, reject) => {
- uni.request({
- method: config.method || 'get',
- timeout: config.timeout || timeout,
- url: baseUrl + config.url,
- data: config.data,
- header: config.header,
- dataType: 'json',
- params: config.params
- }).then(response => {
- /* let [error, res] = response
- if (error) {
- toast('后端接口连接异常')
- reject('后端接口连接异常')
- return
- } */
- const res = response
- const code = res.data.code || 200
- const msg = errorCode[code] || res.data.msg || errorCode['default']
- if (code === 401) {
- showConfirm('登录状态已过期,您可以继续留在该页面,或者重新登录?').then(confirmRes => {
- if (confirmRes.confirm) {
- store.dispatch('LogOut').then(storeRes => {
- uni.reLaunch({
- url: '/pages/login/index'
- })
- })
- }
- })
- reject('无效的会话,或者会话已过期,请重新登录。')
- } else if (code === 500) {
- toast(msg)
- reject('500')
- } else if (code !== 200) {
- toast(msg)
- reject(code)
- }
- if (res.data.encrypt) {
- if (pwdConfig.encryptKey == null) {
- pwdConfig.encryptKey = RSADecrypt(res.data.GoWork)
- }
- res.data.data = JSON.parse(AESDecrypt(res.data.data, pwdConfig.encryptKey))
- }
- console.log(urlOrginal)
- console.log(res.data)
- console.log("***************************************")
- resolve(res.data)
- })
- .catch(error => {
- let {
- message
- } = error
- if (message === 'Network Error') {
- message = '后端接口连接异常'
- } else if (message.includes('timeout')) {
- message = '系统接口请求超时'
- } else if (message.includes('Request failed with status code')) {
- message = '系统接口' + message.substr(message.length - 3) + '异常'
- }
- toast(message)
- reject(error)
- })
- })
- }
- export default request
|