request.js 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194
  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. timeout: 3 * 60 * 1000, // 3分钟等待
  57. withCredentials: true // 携带cookie
  58. })
  59. // 请求拦截器
  60. httpRequest.interceptors.request.use(
  61. function (config) {
  62. if(config.data.access_token){
  63. config.headers['access_token'] = config.data.access_token
  64. }
  65. // if (!isLocalEnv()) {
  66. // if (getQueryVariable('token')) {
  67. // config.headers['access_token'] = getQueryVariable('token')
  68. // }
  69. // } else {
  70. // config.headers['access_token'] = localStorage.getItem('token')
  71. // // config.headers['access_token'] = '4b3ed521-f509-48d9-b907-ab127479df41'
  72. // }
  73. // // 上传文件
  74. // if (config.url == '/apiSys/oss/upload') {
  75. // config.headers['Content-Type'] = 'multipart/form-data'
  76. // } else {
  77. // config.headers['Content-Type'] = 'application/json'
  78. // }
  79. return config
  80. },
  81. function (error) {
  82. return Promise.reject(error)
  83. }
  84. )
  85. //响应拦截
  86. httpRequest.interceptors.response.use(
  87. function (response) {
  88. const res = response.data
  89. // if (res.code == 201) {
  90. // this.ELEMENT.Message.error(res.msg)
  91. // if (!isLocalEnv()) {
  92. // // 跳登录页
  93. // window.location = window.location.origin
  94. // } else {
  95. // localEnvLogin()
  96. // }
  97. // }
  98. return response
  99. },
  100. function (error) {
  101. this.ELEMENT.Message.error(error.message)
  102. return Promise.reject(error)
  103. }
  104. )
  105. function get (url, params) {
  106. return new Promise((resolve, reject) => {
  107. httpRequest
  108. .get(url, { params: params })
  109. .then(res => {
  110. resolve(res.data)
  111. })
  112. .catch(err => {
  113. reject(err.data)
  114. })
  115. })
  116. }
  117. // qs.stringify(data)
  118. function post (url, data, config) {
  119. return new Promise((resolve, reject) => {
  120. httpRequest
  121. .post(url, data, config)
  122. .then(res => {
  123. resolve(res.data)
  124. })
  125. .catch(err => {
  126. reject(err)
  127. })
  128. })
  129. }
  130. function postFile (url, blob) {
  131. return new Promise((resolve, reject) => {
  132. let formdata = new FormData()
  133. formdata.append('multipartFile', blob)
  134. httpRequest
  135. .post(url, formdata)
  136. .then(res => {
  137. resolve(res.data)
  138. })
  139. .catch(err => {
  140. reject(err)
  141. })
  142. })
  143. }
  144. function localEnvLogin () {
  145. post(
  146. '/apiSys/login',
  147. {
  148. username: 'admin',
  149. password: '1q2w3e4r5t'
  150. },
  151. {
  152. transformRequest: [
  153. function (data, headers) {
  154. // 将请求数据转换成功 formdata 接收格式
  155. headers['Content-Type'] = 'application/x-www-form-urlencoded'
  156. return stringify(data)
  157. }
  158. ]
  159. }
  160. ).then(res => {
  161. localStorage.setItem('token', res.data.token || getQueryVariable('token'))
  162. })
  163. }
  164. // 将参数转换成功 formdata 接收格式
  165. function stringify (data) {
  166. let ret = ''
  167. for (const it in data) {
  168. ret += encodeURIComponent(it) + '=' + encodeURIComponent(data[it]) + '&'
  169. }
  170. ret = ret.substring(0, ret.lastIndexOf('&'))
  171. return ret
  172. }
  173. // 格式化日期
  174. function formatDate (time) {
  175. let date = time ? new Date(Number(time)) : new Date();
  176. let Y = date.getFullYear() + '-';
  177. let M = (date.getMonth() + 1 < 10 ? '0' + (date.getMonth() + 1) : date.getMonth() + 1) + '-';
  178. let D = date.getDate() < 10 ? '0' + date.getDate() + ' ' : date.getDate() + ' ';
  179. let h = date.getHours() < 10 ? '0' + date.getHours() + ':' : date.getHours() + ':';
  180. let m = date.getMinutes() < 10 ? '0' + date.getMinutes() + ':' : date.getMinutes() + ':';
  181. let s = date.getSeconds() < 10 ? '0' + date.getSeconds() : date.getSeconds();
  182. return Y + M + D + h + m + s;
  183. }