request.js 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195
  1. //如果部署在同域名的话可以直接取cookie,后端需 HttpOnly 设置成否
  2. // var cookie_name = 'wolfking.jeesharp.session.id'
  3. // getCookie(cookie_name)
  4. // 是否本地环境
  5. function isLocalEnv () {
  6. let domain = window.location.origin
  7. if (['http://127.0.0.1:5500', 'file://'].includes(domain)) {
  8. return true
  9. } else {
  10. return false
  11. }
  12. }
  13. // api 前缀
  14. function getApiUrl () {
  15. // 为线上时
  16. if (!isLocalEnv()) {
  17. return window.location.origin
  18. } else {
  19. // 本地时
  20. // return 'http://sxtc.com:10002' // 内网环境
  21. // return 'http://10.8.8.100:10002' // 内网环境
  22. // return 'http://1.71.170.214:18080' // 线上环境
  23. // return 'http://szxm.sxcig.com:8012' // 线上环境
  24. // return 'http://10.0.0.27:8080' // 超哥环境
  25. // return 'http://10.0.0.22:8080' // 闫敏的环境
  26. // return 'http://10.0.0.8:8080' // 祥慧的环境
  27. // return 'http://10.0.0.115:8080' // 王蒙的环境
  28. return 'http://10.0.0.74:8080'
  29. }
  30. }
  31. // websocket 前缀
  32. function getWsUrl () {
  33. let prefix = location.protocol === 'https:' ? 'wss://' : 'ws://'
  34. // 为线上时
  35. if (!isLocalEnv()) {
  36. return prefix + window.location.host
  37. } else {
  38. return prefix + 'sxtc.com:10002'
  39. // return prefix + '10.0.0.115:8080'
  40. }
  41. }
  42. // minio 前缀
  43. function getMinioUrl () {
  44. let isProduction = location.origin.indexOf('1.71.170.214') != -1
  45. if (isProduction) {
  46. return 'http://1.71.170.214:19000/constr-documents/'
  47. } else {
  48. return 'http://10.8.8.191:9000/constr-documents-test/'
  49. }
  50. }
  51. /** axios封装
  52. * 请求拦截、相应拦截、错误统一处理
  53. */
  54. const httpRequest = axios.create({
  55. // baseURL: 'http://192.168.1.2:8080', // 测试环境
  56. baseURL: 'http://172.21.9.23:8081', // 生产环境
  57. timeout: 3 * 60 * 1000, // 3分钟等待
  58. withCredentials: true // 携带cookie
  59. })
  60. // 请求拦截器
  61. httpRequest.interceptors.request.use(
  62. function (config) {
  63. if(config.data.access_token){
  64. config.headers['access_token'] = config.data.access_token
  65. }
  66. // if (!isLocalEnv()) {
  67. // if (getQueryVariable('token')) {
  68. // config.headers['access_token'] = getQueryVariable('token')
  69. // }
  70. // } else {
  71. // config.headers['access_token'] = localStorage.getItem('token')
  72. // // config.headers['access_token'] = '4b3ed521-f509-48d9-b907-ab127479df41'
  73. // }
  74. // // 上传文件
  75. // if (config.url == '/apiSys/oss/upload') {
  76. // config.headers['Content-Type'] = 'multipart/form-data'
  77. // } else {
  78. // config.headers['Content-Type'] = 'application/json'
  79. // }
  80. return config
  81. },
  82. function (error) {
  83. return Promise.reject(error)
  84. }
  85. )
  86. //响应拦截
  87. httpRequest.interceptors.response.use(
  88. function (response) {
  89. const res = response.data
  90. // if (res.code == 201) {
  91. // this.ELEMENT.Message.error(res.msg)
  92. // if (!isLocalEnv()) {
  93. // // 跳登录页
  94. // window.location = window.location.origin
  95. // } else {
  96. // localEnvLogin()
  97. // }
  98. // }
  99. return response
  100. },
  101. function (error) {
  102. this.ELEMENT.Message.error(error.message)
  103. return Promise.reject(error)
  104. }
  105. )
  106. function get (url, params) {
  107. return new Promise((resolve, reject) => {
  108. httpRequest
  109. .get(url, { params: params })
  110. .then(res => {
  111. resolve(res.data)
  112. })
  113. .catch(err => {
  114. reject(err.data)
  115. })
  116. })
  117. }
  118. // qs.stringify(data)
  119. function post (url, data, config) {
  120. return new Promise((resolve, reject) => {
  121. httpRequest
  122. .post(url, data, config)
  123. .then(res => {
  124. resolve(res.data)
  125. })
  126. .catch(err => {
  127. reject(err)
  128. })
  129. })
  130. }
  131. function postFile (url, blob) {
  132. return new Promise((resolve, reject) => {
  133. let formdata = new FormData()
  134. formdata.append('multipartFile', blob)
  135. httpRequest
  136. .post(url, formdata)
  137. .then(res => {
  138. resolve(res.data)
  139. })
  140. .catch(err => {
  141. reject(err)
  142. })
  143. })
  144. }
  145. function localEnvLogin () {
  146. post(
  147. '/apiSys/login',
  148. {
  149. username: 'admin',
  150. password: '1q2w3e4r5t'
  151. },
  152. {
  153. transformRequest: [
  154. function (data, headers) {
  155. // 将请求数据转换成功 formdata 接收格式
  156. headers['Content-Type'] = 'application/x-www-form-urlencoded'
  157. return stringify(data)
  158. }
  159. ]
  160. }
  161. ).then(res => {
  162. localStorage.setItem('token', res.data.token || getQueryVariable('token'))
  163. })
  164. }
  165. // 将参数转换成功 formdata 接收格式
  166. function stringify (data) {
  167. let ret = ''
  168. for (const it in data) {
  169. ret += encodeURIComponent(it) + '=' + encodeURIComponent(data[it]) + '&'
  170. }
  171. ret = ret.substring(0, ret.lastIndexOf('&'))
  172. return ret
  173. }
  174. // 格式化日期
  175. function formatDate (time) {
  176. let date = time ? new Date(Number(time)) : new Date();
  177. let Y = date.getFullYear() + '-';
  178. let M = (date.getMonth() + 1 < 10 ? '0' + (date.getMonth() + 1) : date.getMonth() + 1) + '-';
  179. let D = date.getDate() < 10 ? '0' + date.getDate() + ' ' : date.getDate() + ' ';
  180. let h = date.getHours() < 10 ? '0' + date.getHours() + ':' : date.getHours() + ':';
  181. let m = date.getMinutes() < 10 ? '0' + date.getMinutes() + ':' : date.getMinutes() + ':';
  182. let s = date.getSeconds() < 10 ? '0' + date.getSeconds() : date.getSeconds();
  183. return Y + M + D + h + m + s;
  184. }