標籤:timeout switch message inter import before 請求 mes bsp
一、路由攔截使用
router.beforeEach((to, from, next) => { if (to.meta.requireAuth) { // 判斷該路由是否需要登入許可權 if (store.state.token) { // 通過vuex state擷取當前的token是否存在 next(); } else { next({ path: ‘/login‘, query: {redirect: to.fullPath} // 將跳轉的路由path作為參數,登入成功後跳轉到該路由 }) } } else { next(); }})
二、攔截器使用
要想統一處理所有http請求和響應,就得用上 axios 的攔截器。通過配置http response inteceptor
,當後端介面返回401 Unauthorized(未授權)
,讓使用者重新登入。
// http request 攔截器axios.interceptors.request.use( config => { if (store.state.token) { // 判斷是否存在token,如果存在的話,則每個http header都加上token config.headers.Authorization = `token ${store.state.token}`; } return config; }, err => { return Promise.reject(err); }); // http response 攔截器axios.interceptors.response.use( response => { return response; }, error => { if (error.response) { switch (error.response.status) { case 401: // 返回 401 清除token資訊並跳轉到登入頁面 store.commit(types.LOGOUT); router.replace({ path: ‘login‘, query: {redirect: router.currentRoute.fullPath} }) } } return Promise.reject(error.response.data) // 返回介面返回的錯誤資訊 });
三、執行個體
/** * http配置 */// 引入axios以及element ui中的loading和message組件import axios from ‘axios‘import { Loading, Message } from ‘element-ui‘// 逾時時間axios.defaults.timeout = 5000// http請求攔截器var loadinginstaceaxios.interceptors.request.use(config => { // element ui Loading方法 loadinginstace = Loading.service({ fullscreen: true }) return config}, error => { loadinginstace.close() Message.error({ message: ‘載入逾時‘ }) return Promise.reject(error)})// http響應攔截器axios.interceptors.response.use(data => {// 響應成功關閉loading loadinginstace.close() return data}, error => { loadinginstace.close() Message.error({ message: ‘載入失敗‘ }) return Promise.reject(error)}) export default axios
如果你是使用了vux,那麼在main.js這樣使用:
Vue.prototype.$http.interceptors.response.use()
參考地址:vue中axios解決跨域問題和攔截器使用
vue+axios 前端實現的常用攔截