亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Vue中的請求攔截器和響應(yīng)攔截器用法及說明

 更新時間:2023年05月24日 10:20:31   作者:小白在線學(xué)前端  
這篇文章主要介紹了Vue中的請求攔截器和響應(yīng)攔截器用法及說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

vue請求攔截器和響應(yīng)攔截器用法

今天就講一下什么是請求攔截器,和請求攔截器的作用,好了,多余的話我就不說了,馬上開始今天的講解

開始啦

請求攔截器

請求攔截器的作用是:

在請求發(fā)送前進行一些操作,例如在每個請求體里面加上token,統(tǒng)一做了處理的,如果要更改也是非常的容易。

關(guān)于攔截

這里只說原理,前端的請求,最終離不開Ajax,像Vue的Vue-Resource、Axios,都只是對Ajax進行了統(tǒng)一的封裝,它暴露出來的攔截器,其實就是寫了一個方法,把Ajax寫在這個方法里面(我們先說請求攔截器),在執(zhí)行的時候,先將請求時要添加給請求頭的那些數(shù)據(jù)(Token、后端要的加密的密碼)先執(zhí)行一遍,都賦值給一個變量,然后再統(tǒng)一傳給Ajax,接下來,就是執(zhí)行Ajax,這就是所謂的請求攔截器,其實就是先執(zhí)行要添加的數(shù)據(jù),然后再執(zhí)行Ajax,如果把這個添加數(shù)據(jù)的過程抽出來,就成了所謂的請求攔截器了

// 請求超時時間
axios.defaults.timeout = 120000
// 添加請求攔截器
axios.interceptors.request.use(
  config => {
    // 在發(fā)送請求之前做些什么
    // 判斷是否存在token,如果存在將每個頁面header都添加token
    if (window.sessionStorage.getItem('DT')) {
      // 請求頭配置全局token
      config.headers.DT = window.sessionStorage.getItem('DT')
    }
    return config
  },
  err => {
    // 對請求錯誤做些什么
    Vue.prototype.$message.error('請求超時')
    return Promise.reject(err)
  }
)

響應(yīng)攔截器

響應(yīng)攔截器的作用就是

在接收到響應(yīng)后再進行一些操作,例如在服務(wù)器返回登錄狀態(tài)失效的時候,需要重登錄,跳轉(zhuǎn)到登錄頁面,

響應(yīng)攔截器,就是是在請求結(jié)果的返回后的同時,先不直接導(dǎo)出,而是先對響應(yīng)碼等等的進行處理,處理好之后再導(dǎo)出給頁面,如果將這個對象響應(yīng)碼的處理過程抽出來,就成了所謂的響應(yīng)攔截器

代碼如下

// 響應(yīng)攔截器
axios.interceptors.response.use(
  response => {
    // res是響應(yīng)的結(jié)果
    switch (response.data.code) {
      case 401:
        // 登錄失效
        // 響應(yīng)成功的攔截
        console.log('響應(yīng)攔截器:')
        // console.log(response.data)
        Vue.prototype.$message.error(response.data.message)
        sessionStorage.removeItem('DT')
        router.push('/login')
        break
      case 404:
        if (response.data.message !== null) {
          Vue.prototype.$message.error(response.data.message)
        } else {
          Vue.prototype.$message.error('未知錯誤')
        }
        break
      case 500:
        // 錯誤
        if (response.data.message !== null) {
          Vue.prototype.$message.error(response.data.message)
        } else {
          Vue.prototype.$message.error('未知錯誤')
        }
        break
      default:
        return response
    }
    return response
  },
  err => {
    if (err.response.data.message) {
      Vue.prototype.$message.error(err.response.data.message)
      return Promise.reject(err.response.data.message) // 返回接口返回的錯誤信息
    } else {
      // 返回狀態(tài)碼不為200時候的錯誤處理
      Vue.prototype.$message.error(err.toString())
      return Promise.resolve(err)
    }
  }
)

頁面中請求接口時:

// 用戶登錄提交
    login() {
      // debugger
      this.$refs.loginFormRef.validate(async valid => {
        if (!valid) return
        if (valid) {const userInfo = {
            username: this.loginForm.username,
            password: this.loginForm.password
          }
          // 登錄之前去除token
          window.sessionStorage.removeItem('DT')
          const { data: res } = await this.$http.post('/system/login', userInfo)
          if (res.code !== 200) {
            this.initCaptcha()
            return
          }
          this.$message.success('登錄成功')
          window.sessionStorage.setItem('DT', res.result.token)
          this.$router.push('/main')
        }
      })
    }

心得:

  • 請求攔截器:其實就是先執(zhí)行要添加的數(shù)據(jù),然后再執(zhí)行Ajax,如果把這個添加數(shù)據(jù)的過程抽出來,就成了所謂的請求攔截器了
  • 響應(yīng)攔截器:就是是在請求結(jié)果的返回后的同時,先不直接導(dǎo)出,而是先對響應(yīng)碼等等的進行處理,處理好之后再導(dǎo)出給頁面,如果將這個對象響應(yīng)碼的處理過程抽出來,就成了所謂的響應(yīng)攔截器

使用axios請求攔截器和響應(yīng)攔截器

在使用一些前后端會話時,需要在請求頭中攜帶一些特殊請求頭,這樣,就需要設(shè)置請求攔截器和響應(yīng)攔截器

開發(fā)項目時,由于后端使用了token令牌,登錄后在前端保存,然后每次請求都要攜帶token,將這些配置寫在main.js文件中是很亂的不易于閱讀,額外配置了axios請求配置模塊 這樣在以后對于請求響應(yīng)都能更好的配置而不會影響其他配置

如果不使用請求攔截,那么對每一條請求每一個狀態(tài)都要特殊處理,如果請求特殊狀態(tài)有數(shù)十個,每個頁面有很多請求,那么頁面會變得很長很臃腫,不好維護。

如何使用?

1.在utils文件夾中創(chuàng)建 一個request.js文件

文件內(nèi)容為(這里必須export這個配置后,才能被):

const service = axios.create({
    timeout: 6000  //請求超時為6秒
}); //創(chuàng)建一個axios, 命名為service

2.先寫請求攔截器的邏輯代碼

//請求攔截器
 service.interceptors.request.use(function(config) {
    // 處理請求之前的配置
    //在請求頭headers加入token校驗
     config.headers["token"] = "aded434088c7bcc595ec1c36c24aea1c"
     return config
 }, function(error) {
      // 請求失敗的處理
     return Promise.reject(error);
 });

3.接著寫響應(yīng)攔截器的邏輯代碼

service.interceptors.response.use(function (response) {
    // 在接收響應(yīng)做些什么,例如跳轉(zhuǎn)到登錄頁
    ......
    return response;
  }, function (error) {
    // 對響應(yīng)錯誤做點什么
    return Promise.reject(error);
  });

4.在統(tǒng)一管理的接口文件api.js使用

5.移除攔截器的方法

axios.interceptors.request.eject(service); //service為第一步中創(chuàng)建的axios

總結(jié)

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • vue中el-table和jsplumb實現(xiàn)連線功能

    vue中el-table和jsplumb實現(xiàn)連線功能

    本文主要介紹了el-table和jsplumb實現(xiàn)連線功能,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-07-07
  • vue環(huán)境變量配置之process.env解讀

    vue環(huán)境變量配置之process.env解讀

    這篇文章主要介紹了vue環(huán)境變量配置之process.env解讀,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • 最細致的vue.js基礎(chǔ)語法 值得收藏!

    最細致的vue.js基礎(chǔ)語法 值得收藏!

    這篇文章主要為大家推薦了一篇值得收藏和學(xué)習(xí)的vue.js最細致的基礎(chǔ)語法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-11-11
  • vue 中的 render 函數(shù)作用詳解

    vue 中的 render 函數(shù)作用詳解

    這篇文章主要介紹了vue 中的 render 函數(shù)作用,通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-02-02
  • 關(guān)于移動端與大屏幕自適應(yīng)適配方案

    關(guān)于移動端與大屏幕自適應(yīng)適配方案

    這篇文章主要介紹了關(guān)于移動端與大屏幕自適應(yīng)適配方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-10-10
  • vue 父組件通過v-model接收子組件的值的代碼

    vue 父組件通過v-model接收子組件的值的代碼

    這篇文章主要介紹了vue 父組件通過v-model接收子組件的值的代碼,代碼簡單易懂,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-10-10
  • Vue+Element實現(xiàn)表格編輯、刪除、以及新增行的最優(yōu)方法

    Vue+Element實現(xiàn)表格編輯、刪除、以及新增行的最優(yōu)方法

    這篇文章主要為大家詳細介紹了Vue+Element實現(xiàn)表格的編輯、刪除、以及新增行的最優(yōu)方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-05-05
  • AntV+Vue實現(xiàn)導(dǎo)出圖片功能

    AntV+Vue實現(xiàn)導(dǎo)出圖片功能

    AntV?組織圖操作完畢以后,需要點擊按鈕將畫布以圖片的形式導(dǎo)出,這篇文章主要介紹了AntV結(jié)合Vue實現(xiàn)導(dǎo)出圖片功能,需要的朋友可以參考下
    2023-01-01
  • 基于vue實現(xiàn)簡易打地鼠游戲

    基于vue實現(xiàn)簡易打地鼠游戲

    這篇文章主要為大家詳細介紹了基于vue實現(xiàn)簡易打地鼠游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-08-08
  • 記一次用ts+vuecli4重構(gòu)項目的實現(xiàn)

    記一次用ts+vuecli4重構(gòu)項目的實現(xiàn)

    這篇文章主要介紹了記一次用ts+vuecli4重構(gòu)項目的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-05-05

最新評論