request.js 7.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305
  1. import unirequest from '../plugins/uni_request.js'
  2. import store from "../store";
  3. // import { autoAuth } from '@/utils/common.js';
  4. import md5 from 'js-md5';
  5. import {
  6. uniShowToast,
  7. successToast,
  8. loadingToast,
  9. uniHideToast,
  10. uniHideLoading,
  11. uniShowModal
  12. } from './uni_api'
  13. import {
  14. VUE_APP_URL
  15. } from '../config.js'
  16. // 初始化自定义参数 login 是否需要登录权限 cancel 是否取消上次请求
  17. const defaultOptions = {
  18. login: true,
  19. auth: false,
  20. cancel: false,
  21. loading: true, //是否显示 请求加载中
  22. warn: true //是否异常弹窗提示
  23. };
  24. // 初始化请求
  25. let instance = unirequest.create({
  26. baseURL: VUE_APP_URL,
  27. timeout: 100000,
  28. debug: true
  29. });
  30. let setCancel;
  31. // 请求拦截器
  32. instance.interceptors.request.use(
  33. config => {
  34. var token = store.state.token||uni.getStorageSync('frontlixiangsid');//'7221b77a-899b-492b-8263-9507f5c470e9';// store.state.token
  35. //console.log("frontlixiangsid:"+token);
  36. config.header['frontlixiangsid']= token;//登录token 标志id
  37. config.header['platType']= 'slb';
  38. config.header['mpType'] = 'engineer';
  39. config.header['appType'] = 'ma';
  40. config.cancelToken = new unirequest.CancelToken(function executor(c) {
  41. setCancel = c; //记录当前请求
  42. });
  43. config.timeStamp= new Date().getTime();
  44. var jsToken ="";//防重复提交
  45. jsToken = md5(JSON.stringify(config))
  46. console.log('jsToken' + jsToken);
  47. console.log(config);
  48. config.data['tokenId'] = jsToken;
  49. return config
  50. })
  51. // 响应拦截器
  52. instance.interceptors.response.use(
  53. response => {
  54. // console.log('响应成功', response)
  55. return response
  56. })
  57. // 读取cookie
  58. function getCookie(cookie,c_name) {
  59. if (cookie && cookie.length > 0){
  60. let c_start = cookie.indexOf(c_name + "=")
  61. if (c_start != -1){
  62. c_start = c_start + c_name.length + 1
  63. let c_end = cookie.indexOf(";", c_start)
  64. if (c_end == -1)
  65. c_end = cookie.length
  66. return unescape(cookie.substring(c_start, c_end))
  67. }
  68. }
  69. return ""
  70. }
  71. // 请求主体
  72. function baseRequest(config, options) {
  73. const {
  74. login,
  75. auth,
  76. cancel,
  77. loading = true,
  78. warn
  79. } = options;
  80. if (options.cancel) {
  81. cancelRequest()
  82. }
  83. loadingStatus(loading, true)
  84. if (login && !store.state.token) {
  85. loadingStatus(loading, false);
  86. // autoAuth();
  87. }
  88. return instance.request(config).then(res => {
  89. if(config.url==='/slbMpAutoLogin'){
  90. try{
  91. var cookie = res.header["set-cookie"]||res.header["Set-Cookie"];
  92. let frontlixiangsid = getCookie(cookie,"frontlixiangsid")||res.resultMap.frontlixiangsid;
  93. console.log('cookie',frontlixiangsid);
  94. if(frontlixiangsid&&frontlixiangsid!='deleteMe'){
  95. store.state.token = frontlixiangsid;
  96. uni.setStorageSync('frontlixiangsid',frontlixiangsid)
  97. }
  98. }catch(err){
  99. console.log(err);
  100. }
  101. }
  102. //console.log(config);
  103. loadingStatus(loading, false)
  104. //console.log(res);
  105. if (res.statusCode) {
  106. let data = res.data;
  107. console.log('instance.request',res);
  108. console.log('instance.request data',data);
  109. if (res.statusCode === 200) {
  110. console.log('instance.request data 1',data);
  111. if (data.state == 1) {
  112. return Promise.resolve(data);
  113. }
  114. else if(data.msg&&(data.msg=='请勿频繁操作'||data.msg.indexOf('不能再次使用')>-1)){
  115. uniShowToast(data.msg);
  116. return;
  117. }
  118. else if(data._redirect||data.msg=='未登录'){
  119. // store.commit("LOGOUT");
  120. uni.reLaunch({
  121. url: '/pages/index/auth'
  122. });
  123. return Promise.resolve(data);
  124. }
  125. else if(data=='' || data=='success'|| data._redirect){
  126. console.log('instance.request data 2',data);
  127. // store.commit("LOGOUT");
  128. //未登录
  129. if (!store.state.isGOAuth) {
  130. store.commit("SET_GO_AUTH", true);
  131. //判断是否是第一次加载第一次加载未登录不用弹框提醒
  132. if(store.state.isFirstLoad){
  133. store.state.isFirstLoad=false;
  134. uni.redirectTo({
  135. url: '/pages/Login/Login'
  136. });
  137. return;
  138. }else{
  139. store.state.isFirstLoad=false;
  140. uniShowModal('', '账号过期重新登录认证', {
  141. showCancel: false,
  142. success: (res) => {
  143. //添加跳转 微信绑定公众号页面
  144. uni.redirectTo({
  145. url: '/pages/auth/auth'
  146. });
  147. }
  148. })
  149. return;
  150. }
  151. } else {
  152. console.log('路由已存在,不再重复跳转')
  153. return;
  154. }
  155. data.msg='未登录';
  156. return Promise.reject(data);
  157. } else {
  158. console.log('instance.request data 3',data);
  159. //data.state == -301||
  160. if(data.msg == undefined){
  161. if(uni.getStorageSync("loginFlag")){
  162. uni.redirectTo({
  163. url: "/pages/Login/Login"
  164. });
  165. }
  166. return;
  167. }
  168. if (warn) {
  169. uni.redirectTo({
  170. url: '/pages/error/error?code='+data.state+'&msg='+data.msg
  171. });
  172. return;
  173. }
  174. return Promise.resolve(data);
  175. }
  176. return Promise.resolve(res.data);
  177. } else {
  178. if (warn) {
  179. responseError({
  180. code: res.statusCode
  181. })
  182. }
  183. return Promise.reject(res.data);
  184. }
  185. } else {
  186. return Promise.reject(res.data);
  187. }
  188. loadingStatus(loading, false);
  189. }).catch(err => {
  190. loadingStatus(loading, false)
  191. // if (warn) {
  192. uniShowToast(err)
  193. // }
  194. return Promise.reject(err);
  195. })
  196. }
  197. function cancelRequest() {
  198. if (typeof setCancel === 'function') {
  199. setCancel('取消请求')
  200. }
  201. loadingStatus(loading, false);
  202. }
  203. // 定义请求提示
  204. const loadingStatus = (loading, type) => {
  205. if (loading) {
  206. if (type) {
  207. // loadingToast('正在请求中');
  208. setTimeout(function () {
  209. uniHideLoading();
  210. }, 5000);//防水异常加载不关闭影响操作
  211. } else {
  212. uniHideLoading();
  213. }
  214. } else {
  215. return
  216. }
  217. }
  218. // 请求返回statusCode
  219. const responseError = ({
  220. code
  221. }) => {
  222. let content = '';
  223. switch (code) {
  224. case 400:
  225. content = '请求参数错误';
  226. break
  227. case 401:
  228. content = '未授权,请重新登录-401';
  229. break
  230. case 403:
  231. content = '没有访问权限-403';
  232. break
  233. case 404:
  234. content = '请求错误,未找到该资源-404';
  235. break
  236. case 405:
  237. content = '请求方式错误-405';
  238. break
  239. case 408:
  240. content = '请求超时';
  241. break
  242. case 500:
  243. content = '服务器异常-500';
  244. break
  245. case 501:
  246. content = '服务未实现';
  247. break
  248. case 502:
  249. content = '网关错误';
  250. break
  251. case 503:
  252. content = '服务不可用';
  253. break
  254. case 504:
  255. content = '网关超时';
  256. break
  257. case 505:
  258. content = 'HTTP版本不受支持';
  259. break
  260. default:
  261. content = '请求异常-' + code;
  262. break
  263. }
  264. uniShowModal('', content, {
  265. showCancel: false,
  266. success: (res) => {
  267. console.log(res)
  268. }
  269. })
  270. }
  271. const request = ['get', 'post', 'put', 'delete', 'connect', 'head', 'options', 'trace'].reduce((request, method) => {
  272. request[method] = (url, data, options = {}) => baseRequest({
  273. url,
  274. method,
  275. data
  276. }, { ...defaultOptions,
  277. ...options
  278. });
  279. return request;
  280. }, {});
  281. export default request;