vue的請(qǐng)求攔截,http請(qǐng)求攔截器

本文引用CSDN博主面條請(qǐng)不要欺負(fù)漢堡;
鏈接https://blog.csdn.net/gao_xu_520/article/details/104539014

  • 登陸攔截
    用戶登錄成功后服務(wù)端返回token的值,然后前端使用axios中請(qǐng)求攔截器(service.interceptors.request.use)再每個(gè)的請(qǐng)求接口上加上Authorization:token的值葬毫,服務(wù)端通過(guò)這個(gè)Authorization來(lái)獲取token的值,來(lái)進(jìn)行判斷token的值是否過(guò)期,如果過(guò)期則接口返回403,前端得到403的狀態(tài),則提示用戶返回登錄頁(yè)馒铃。

  • request.js

import axios from 'axios';
import { Message, MessageBox } from 'element-ui';
import router from '../router';
/**
 * 提示函數(shù)
 * 禁止點(diǎn)擊蒙層闸婴、顯示一秒后關(guān)閉
 */
const tip = msg => {
    Message({
        message: msg,
        duration: 1000
    })
}
 
/**
 * 跳轉(zhuǎn)登錄頁(yè)
 * 攜帶當(dāng)前頁(yè)面路由,以期在登錄頁(yè)面完成登錄后返回當(dāng)前頁(yè)面
 */
const toLogin = () => {
    router.replace({
        path: '/login'
    });
}
 
// 創(chuàng)建axios實(shí)例
const service = axios.create({
    baseURL: process.env.VUE_APP_BASE_API, // url = base url + request url
    // withCredentials: true, // send cookies when cross-domain requests
    timeout: 5000 // request timeout
})
// 設(shè)置post請(qǐng)求頭
service.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded';
 
// 請(qǐng)求攔截器
service.interceptors.request.use(
    config => {
        // 登錄流程控制中冲茸,根據(jù)本地是否存在token判斷用戶的登錄情況
        // 但是即使token存在,也有可能token是過(guò)期的缅帘,所以在每次的請(qǐng)求頭中攜帶token
        // 后臺(tái)根據(jù)攜帶的token判斷用戶的登錄情況噪裕,并返回給我們對(duì)應(yīng)的狀態(tài)碼
        // 而后我們可以在響應(yīng)攔截器中,根據(jù)狀態(tài)碼進(jìn)行一些統(tǒng)一的操作股毫。
        const token = localStorage.getItem('token');
        token && (config.headers.Authorization = token);
        return config
    },
    error => {
        // 處理請(qǐng)求錯(cuò)誤
        return Promise.reject(error)
    }
)
// 響應(yīng)攔截器
service.interceptors.response.use(
    //請(qǐng)求成功
    response => {
        const res = response.data;
        if (res.code !== 200 && res.status !== 200) {
            return Promise.reject(res)
        } else {
            return res
        }
    },
    //請(qǐng)求失敗
    error => {
        const {
            response
        } = error;
        if (response) {
            // 請(qǐng)求已發(fā)出膳音,但是不在30分鐘的范圍
            errorHandle(response.status, response.data.message);
            return Promise.reject(response);
        } else {
            // 處理斷網(wǎng)的情況
            // eg:請(qǐng)求超時(shí)或斷網(wǎng)時(shí),更新state的network狀態(tài)
            // network狀態(tài)在app.vue中控制著一個(gè)全局的斷網(wǎng)提示組件的顯示隱藏
            // 關(guān)于斷網(wǎng)組件中的刷新重新獲取數(shù)據(jù)铃诬,會(huì)在斷網(wǎng)組件中說(shuō)明
            // store.commit('changeNetwork', false);
        }
    }
)
/**
 * 請(qǐng)求失敗后的錯(cuò)誤統(tǒng)一處理
 * @param {Number} status 請(qǐng)求失敗的狀態(tài)碼
 */
const errorHandle = (status, other) => {
    // 狀態(tài)碼判斷
    switch (status) {
        // 401: 未登錄狀態(tài)祭陷,跳轉(zhuǎn)登錄頁(yè)
        case 401:
            toLogin();
            break;
        // 403 token過(guò)期
        // 清除token并跳轉(zhuǎn)登錄頁(yè)
        case 403:
            localStorage.removeItem('token');
            MessageBox({
                message: '登錄過(guò)期,請(qǐng)重新登錄',
                callback: action => {
                    toLogin();
                }
            })
            break;
        // 404請(qǐng)求不存在
        case 404:
            tip('請(qǐng)求的資源不存在');
            break;
    }
}
export default service
image.png
  • 登陸接口
interface.js
 
import request from '@/utils/request'
const base = {
    local: 'localhost',
    dev: 'http://10.16.3330.39:8093/',
}
 
 
//登錄接口
export function dischargeLogin(params) {
    return request.post(`${base.dev}discharge/login`, params)
}
 
login.vue
 
import * as Api from "@/api/interface";
 
Api.login(this.loginForm).then(res=>{
    this.$router.push({
        path: "/home"
    });
    localStorage.setItem("token", res.data.token);
}).catch((e) => {
    Message({
        message: e.msg,
        type: 'error',
        duration: 1000
    })
});

本文引用CSDN博主面條請(qǐng)不要欺負(fù)漢堡;
鏈接https://blog.csdn.net/gao_xu_520/article/details/104539014

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末趣席,一起剝皮案震驚了整個(gè)濱河市兵志,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌宣肚,老刑警劉巖想罕,帶你破解...
    沈念sama閱讀 221,820評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異霉涨,居然都是意外死亡按价,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,648評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門笙瑟,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)楼镐,“玉大人,你說(shuō)我怎么就攤上這事往枷】虿” “怎么了?”我有些...
    開(kāi)封第一講書人閱讀 168,324評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵错洁,是天一觀的道長(zhǎng)秉宿。 經(jīng)常有香客問(wèn)我,道長(zhǎng)屯碴,這世上最難降的妖魔是什么描睦? 我笑而不...
    開(kāi)封第一講書人閱讀 59,714評(píng)論 1 297
  • 正文 為了忘掉前任,我火速辦了婚禮窿锉,結(jié)果婚禮上酌摇,老公的妹妹穿的比我還像新娘膝舅。我一直安慰自己嗡载,他們只是感情好窑多,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,724評(píng)論 6 397
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著洼滚,像睡著了一般埂息。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上遥巴,一...
    開(kāi)封第一講書人閱讀 52,328評(píng)論 1 310
  • 那天千康,我揣著相機(jī)與錄音,去河邊找鬼铲掐。 笑死拾弃,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的摆霉。 我是一名探鬼主播豪椿,決...
    沈念sama閱讀 40,897評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼携栋!你這毒婦竟也來(lái)了搭盾?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書人閱讀 39,804評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤婉支,失蹤者是張志新(化名)和其女友劉穎鸯隅,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體向挖,經(jīng)...
    沈念sama閱讀 46,345評(píng)論 1 318
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡蝌以,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,431評(píng)論 3 340
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了何之。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片饼灿。...
    茶點(diǎn)故事閱讀 40,561評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖帝美,靈堂內(nèi)的尸體忽然破棺而出碍彭,到底是詐尸還是另有隱情,我是刑警寧澤悼潭,帶...
    沈念sama閱讀 36,238評(píng)論 5 350
  • 正文 年R本政府宣布庇忌,位于F島的核電站,受9級(jí)特大地震影響舰褪,放射性物質(zhì)發(fā)生泄漏皆疹。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,928評(píng)論 3 334
  • 文/蒙蒙 一略就、第九天 我趴在偏房一處隱蔽的房頂上張望捎迫。 院中可真熱鬧表牢,春花似錦、人聲如沸崔兴。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 32,417評(píng)論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)敲茄。三九已至位谋,卻和暖如春堰燎,著一層夾襖步出監(jiān)牢的瞬間掏父,已是汗流浹背秆剪。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 33,528評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工赊淑, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人鸟款。 一個(gè)月前我還...
    沈念sama閱讀 48,983評(píng)論 3 376
  • 正文 我出身青樓膏燃,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親组哩。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,573評(píng)論 2 359

推薦閱讀更多精彩內(nèi)容