(二)vue.js中axios的封裝(參考)
阿新 • • 發佈:2018-11-10
基於前文所述,axios 是一個基於Promise 用於瀏覽器和 nodejs 的 HTTP 客戶端,它有很多優秀的特性,例如攔截請求和響應、取消請求、轉換json、客戶端防禦XSRF等。
如果還對axios不瞭解的,可以移步axios文件,axios使用說明。
安裝
cnpm install axios --save
在專案src下新建request/http.js檔案,並引入axios
/** * axios封裝:請求攔截,響應攔截,錯誤編碼 */ import axios from 'axios'
設定請求超時時間
/** * 預設10S請求超時 */axios.defaults.timeout = 10000;
設定post請求頭
/** * 設定post請求頭 */ axios.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded;charset=UTF-8';
設定攔截器攔截請求
/** * 請求攔截器 */ axios.interceptors.request.use( config => { // 每次傳送請求之前判斷是否存在token,如果存在,則統一在http請求的header都加上token,不用每次請求都手動添加了// 即使本地存在token,也有可能token是過期的,所以在響應攔截器中要對返回狀態進行判斷 const token = store.state.token; token && (config.headers.Authorization = token); return config; }, error => { return Promise.error(error); } )
響應請求攔截以及返回伺服器狀態碼
// 響應攔截器 axios.interceptors.response.use( response=> { if (response.status === 200) { return Promise.resolve(response); } else { return Promise.reject(response); } }, // 伺服器狀態碼不是200的情況 error => { if (error.response.status) { switch (error.response.status) { // 401: 未登入 // 未登入則跳轉登入頁面,並攜帶當前頁面的路徑 // 在登入成功後返回當前頁面,這一步需要在登入頁操作。 case 401: router.replace({ path: '/login', query: { redirect: router.currentRoute.fullPath } }); break; // 403 token過期 // 登入過期對使用者進行提示 // 清除本地token和清空vuex中token物件 // 跳轉登入頁面 case 403: Toast({ message: '登入過期,請重新登入', duration: 1000, forbidClick: true }); // 清除token localStorage.removeItem('token'); store.commit('loginSuccess', null); // 跳轉登入頁面,並將要瀏覽的頁面fullPath傳過去,登入成功後跳轉需要訪問的頁面 setTimeout(() => { router.replace({ path: '/login', query: { redirect: router.currentRoute.fullPath } }); }, 1000); break; // 404請求不存在 case 404: Toast({ message: '網路請求不存在', duration: 1500, forbidClick: true }); break; // 其他錯誤,直接丟擲錯誤提示 default: Toast({ message: error.response.data.message, duration: 1500, forbidClick: true }); } return Promise.reject(error.response); } } )
封裝get請求和post請求
/** * get請求 * @param {String} url 請求地址 * @param {Object} params 請求引數 */ export function get(url, params) { return new Promise((resolve, reject) => { axios.get(url, { params: params }).then(res => { resolve(res.data); }).catch(err => { reject(err.data) }) }); }