request.js 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112
  1. import store from '@/store'
  2. import config from '@/config'
  3. import {
  4. getToken,
  5. getSsoAdminToken
  6. } from '@/utils/auth'
  7. import errorCode from '@/utils/errorCode'
  8. import {
  9. toast,
  10. showConfirm,
  11. tansParams
  12. } from '@/utils/common'
  13. const ssoToken = getSsoAdminToken()
  14. let timeout = 10000
  15. const baseUrl = config.baseUrl
  16. const request = config => {
  17. // 是否需要设置 token
  18. const isToken = (config.headers || {}).isToken === false
  19. config.header = config.header || {}
  20. if (getToken() && !isToken) {
  21. config.header['Authorization'] = 'Bearer ' + getToken()
  22. }
  23. // 存在ssoToken
  24. // console.log(ssoToken,getSsoAdminToken(),'ssoTokenrequest')
  25. if (getSsoAdminToken()) {
  26. config.header['xxl_sso_sessionid'] = getSsoAdminToken() // 让每个请求携带自定义ssoToken 请根据实际情况自行修改
  27. }
  28. if (config.method == 'get') {
  29. config.params = {
  30. ...config.params,
  31. _t: new Date().getTime() / 1000
  32. }
  33. }
  34. // get请求映射params参数
  35. if (config.params) {
  36. let url = config.url + '?' + tansParams(config.params)
  37. url = url.slice(0, -1)
  38. config.url = url
  39. }
  40. return new Promise((resolve, reject) => {
  41. uni.request({
  42. method: config.method || 'get',
  43. timeout: config.timeout || timeout,
  44. url: config.baseUrl || baseUrl + config.url,
  45. data: config.data,
  46. header: config.header,
  47. dataType: 'json'
  48. }).then(response => {
  49. let [error, res] = response
  50. if (error) {
  51. console.log(error,config.baseUrl || baseUrl + config.url,'error')
  52. toast('后端接口连接异常')
  53. reject('后端接口连接异常')
  54. return
  55. }
  56. const code = res.data.code || 200
  57. const msg = errorCode[code] || res.data.msg || errorCode['default']
  58. if (code === 401) {
  59. showConfirm('登录状态已过期,请重新登录!').then(res => {
  60. if (res.confirm) {
  61. store.dispatch('LogOut').then(res => {
  62. uni.reLaunch({
  63. url: '/pages/login'
  64. })
  65. })
  66. }
  67. })
  68. reject('无效的会话,或者会话已过期,请重新登录。')
  69. } else if (code === 500) {
  70. toast(msg)
  71. reject('500')
  72. } else if (code === 501) {
  73. if (msg.indexOf('sso not login') > -1) {
  74. showConfirm('单点秘钥不存在,请重新登录!').then(res => {
  75. if (res.confirm) {
  76. store.dispatch('LogOut').then(res => {
  77. uni.reLaunch({
  78. url: '/pages/login'
  79. })
  80. })
  81. }
  82. })
  83. reject('无效的会话,或者会话已过期,请重新登录。')
  84. } else {
  85. toast(msg)
  86. reject('501')
  87. }
  88. } else if (code !== 200) {
  89. toast(msg)
  90. reject(code)
  91. }
  92. resolve(res.data)
  93. })
  94. .catch(error => {
  95. let {
  96. message
  97. } = error
  98. if (message === 'Network Error') {
  99. message = '后端接口连接异常'
  100. } else if (message.includes('timeout')) {
  101. message = '系统接口请求超时'
  102. } else if (message.includes('Request failed with status code')) {
  103. message = '系统接口' + message.substr(message.length - 3) + '异常'
  104. }
  105. toast(message)
  106. reject(error)
  107. })
  108. })
  109. }
  110. export default request