1. 程式人生 > >(二)vue.js中axios的封裝(參考)

(二)vue.js中axios的封裝(參考)

基於前文所述,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)
        })
    });
}