React攔截器以及代理設(shè)置

設(shè)置攔截器封裝axios的get post請求:

初始化項(xiàng)目后颠放,我們在src目錄下創(chuàng)建utils文件夾伪朽,內(nèi)包含api.js和http.js兩個文件帮毁。

api.js 主要包含我們請求后臺的接口地址溜宽,簡單舉個例子:

let api = {
    home: '/api/home/content',
    login: `/api/sso/login`,
    ...
}

export default api

接下來吉拳,就是封裝axios的http.js:首先我們需要安裝axios的依賴:

yarn add axios -D or npm i axios -D

安裝完成依賴之后,就需要在http.js中引入:

import axios from "axios";

let baseUrl = 'https://192.168.0.125:8085'

// 創(chuàng)建axios實(shí)例适揉,在這里可以設(shè)置請求的默認(rèn)配置
const instance = axios.create({    
    timeout: 10000, // 設(shè)置超時時間10s
    baseURL: baseUrl   // 根據(jù)自己配置的反向代理去設(shè)置不同環(huán)境的baseUrl
})
// 文檔中的統(tǒng)一設(shè)置post請求頭留攒。下面會說到post請求的幾種'Content-Type'
instance.defaults.headers.post['Content-Type'] = 'application/json'

/** 添加請求攔截器 **/
instance.interceptors.request.use(config => {
    config.headers['token'] = sessionStorage.getItem('token') || ''
    return config
}, error => {
    // 對請求錯誤做些什么
    return Promise.reject(error)
})

/** 添加響應(yīng)攔截器  **/
instance.interceptors.response.use(response => {
    // console.log(response)
    // 響應(yīng)結(jié)果里的 statusText: ''是我與后臺的約定煤惩,大家可以根據(jù)實(shí)際情況去做對應(yīng)的判斷
    if (response.statusText === '') {     
        return Promise.resolve(response.data)
    } else {
        return Promise.reject(response.data.message)
    }
}, error => {
    if (error.response) {
        // token或者登陸失效情況下跳轉(zhuǎn)到登錄頁面,根據(jù)實(shí)際情況稼跳,在這里可以根據(jù)不同的響應(yīng)錯誤結(jié)果盟庞,做對應(yīng)的事。這里我以401判斷為例
        if (error.response.status === 401) {    
            //針對框架跳轉(zhuǎn)到登陸頁面
            this.props.history.push('/login');
        }
        return Promise.reject(error)
    } else {
        return Promise.reject('請求超時, 請刷新重試')
    }
})

/* 統(tǒng)一封裝get請求 */
export const get = (url, params, config = {}) => {
    return new Promise((resolve, reject) => {
        instance({
            method: 'get',
            url,
            params,
            ...config
        }).then(response => {
            resolve(response)
        }).catch(error => {
            reject(error)
        })
    })
}

/* 統(tǒng)一封裝post請求  */
export const post = (url, data, config = {}) => {
    return new Promise((resolve, reject) => {
        instance({
            method: 'post',
            url,
            data,
            ...config
        }).then(response => {
            resolve(response)
        }).catch(error => {
            reject(error)
        })
    })
}

封裝完get post請求之后汤善,我們需要在react的原型鏈上什猖,綁定get和post方法,修改 src/index.js 文件:

import React, { Component } from 'react';
import { get, post } from './utils/http';
import api from './utils/api';

// 注意:Vue 框架是在Vue.prototype原型上綁定红淡,而react不是在React.prototype原型上綁定不狮,而是在Component上綁定

Component.prototype.get = get;
Component.prototype.post = post;
Component.prototype.api = api;

最后就是接口的請求,上一篇文章有所提及在旱,按照要求請求接口即可摇零。

Tips: 在接口的請求過程中,可能會遇到跨域的問題桶蝎,接下來解決跨域的問題:
首先驻仅,跨域我們需要用到 http-proxy-middleware 這個中間件,去設(shè)置代理

yarn add http-proxy-middleware -D or npm i http-proxy-middleware -D

然后我們需要在src目錄下新建setupProxy.js文件:

// 新版舍棄了proxy登渣,采用的是 createProxyMiddleware 
const { createProxyMiddleware } = require("http-proxy-middleware");
 
module.exports = function(app) {
    app.use("/api",
        createProxyMiddleware({
            target: "https://192.168.0.125:8085",                   // 跨域地址
            changeOrigin: true,
            pathRewrite: {
                "^/api": ""
            }
        })
    );
};
// dva代理設(shè)置
{
    "proxy": {
        "/apis": {
            "target": "https://192.168.0.1:8085",                   // 跨域地址
            "changeOrigin": true,
            "pathRewrite": {
                "^/apis": ""
            }
        }
    }
}

到此噪服,我們就可以跨域請求后臺接口地址。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末胜茧,一起剝皮案震驚了整個濱河市粘优,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌呻顽,老刑警劉巖雹顺,帶你破解...
    沈念sama閱讀 207,113評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異廊遍,居然都是意外死亡嬉愧,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,644評論 2 381
  • 文/潘曉璐 我一進(jìn)店門喉前,熙熙樓的掌柜王于貴愁眉苦臉地迎上來英染,“玉大人,你說我怎么就攤上這事被饿。” “怎么了搪搏?”我有些...
    開封第一講書人閱讀 153,340評論 0 344
  • 文/不壞的土叔 我叫張陵狭握,是天一觀的道長。 經(jīng)常有香客問我疯溺,道長论颅,這世上最難降的妖魔是什么哎垦? 我笑而不...
    開封第一講書人閱讀 55,449評論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮恃疯,結(jié)果婚禮上漏设,老公的妹妹穿的比我還像新娘。我一直安慰自己今妄,他們只是感情好郑口,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,445評論 5 374
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著盾鳞,像睡著了一般犬性。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上腾仅,一...
    開封第一講書人閱讀 49,166評論 1 284
  • 那天乒裆,我揣著相機(jī)與錄音,去河邊找鬼推励。 笑死鹤耍,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的验辞。 我是一名探鬼主播稿黄,決...
    沈念sama閱讀 38,442評論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼受神!你這毒婦竟也來了抛猖?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,105評論 0 261
  • 序言:老撾萬榮一對情侶失蹤鼻听,失蹤者是張志新(化名)和其女友劉穎财著,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體撑碴,經(jīng)...
    沈念sama閱讀 43,601評論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡撑教,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,066評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了醉拓。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片伟姐。...
    茶點(diǎn)故事閱讀 38,161評論 1 334
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖亿卤,靈堂內(nèi)的尸體忽然破棺而出愤兵,到底是詐尸還是另有隱情,我是刑警寧澤排吴,帶...
    沈念sama閱讀 33,792評論 4 323
  • 正文 年R本政府宣布秆乳,位于F島的核電站,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏屹堰。R本人自食惡果不足惜肛冶,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,351評論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望扯键。 院中可真熱鬧睦袖,春花似錦、人聲如沸荣刑。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,352評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽嘶摊。三九已至延蟹,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間叶堆,已是汗流浹背阱飘。 一陣腳步聲響...
    開封第一講書人閱讀 31,584評論 1 261
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留虱颗,地道東北人沥匈。 一個月前我還...
    沈念sama閱讀 45,618評論 2 355
  • 正文 我出身青樓,卻偏偏與公主長得像忘渔,于是被迫代替她去往敵國和親高帖。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,916評論 2 344