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

Vue3請求攔截器里如何配置token

 更新時間:2024年08月28日 17:14:38   作者:奔跑的小G  
這篇文章主要介紹了Vue3請求攔截器里如何配置token,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教

Vue3請求攔截器配置token

// axios請求攔截器
httpInstance.interceptors.request.use(config => {
   console.log('請求攔截器',config);
   const userStore = useUserStore()
   const token = userStore.userInfo.token
   if(token){
   //固定寫法
    config.headers.Authorization = `Bearer ${token}` 
    //注意Bearer后面的空格
   }
  return config
}, e => Promise.reject(e))

Vue3的axios請求封裝,請求攔截,相應(yīng)攔截

對于三者放在Service.js中封裝,方便使用

axios.create 的作用是創(chuàng)建一個新的 axios 實(shí)例,該實(shí)例可以具有自定義配置。

通過使用 axios.create,您可以為任何 API 生成一個客戶端,并在使用同一客戶端的任何調(diào)用中重復(fù)使用相同的配置。

這使得在應(yīng)用程序中使用多個 API 時更加方便,因?yàn)槟梢詾槊總€ API 創(chuàng)建一個單獨(dú)的實(shí)例,并在每個實(shí)例中設(shè)置不同的配置。

axios.create 方法接受一個配置對象作為參數(shù),該對象包含以下屬性:

  • baseURL:用于所有請求的基本 URL。
  • headers:要發(fā)送的自定義 headers。
  • timeout:指定請求超時之前的毫秒數(shù)。
  • withCredentials:指示是否應(yīng)該使用跨站點(diǎn)訪問控制(CORS)憑據(jù)。
  • xsrfCookieName:用作 xsrf 令牌值的cookie的名稱。
  • xsrfHeaderName:包含 xsrf 令牌值的 HTTP 頭的名稱。

例如,以下代碼創(chuàng)建了一個新的 axios 實(shí)例,并將其配置為使用 /api/ 作為基本 URL:

const instance = axios.create({
  baseURL: '/api/'
});

axios請求封裝

// 用create創(chuàng)建axios實(shí)例
const Service = axios.create({
    timeout: 3000,
    baseURL: 'http://127.0.0.1:8888/api/private/v1/',
    headers: { 'Content-type': 'application/json;charset=utf-8' }

})

// get 數(shù)據(jù)請求封裝
export const get = config => {
    return Service({
        ...config,
        method: 'get',
        data: config.data,
    })

}

// post 數(shù)據(jù)請求封裝
export const post = config => {
    return Service({
        ...config,
        method: 'post',
        data: config.data,
    })

}

請求攔截和響應(yīng)攔截

在 Vue3 中,可以使用 Axios 庫來進(jìn)行 HTTP 請求。Axios 庫提供了請求攔截器和響應(yīng)攔截器,以便在請求發(fā)送和響應(yīng)返回時執(zhí)行一些操作。

請求攔截器可以用于在請求發(fā)送前執(zhí)行一些操作,例如添加 token、設(shè)置請求頭等。響應(yīng)攔截器可以用于在響應(yīng)返回后執(zhí)行一些操作,例如處理錯誤信息、剝離無效數(shù)據(jù)等。

let loadingObj = null;
// 請求攔截,增加loading,對請求統(tǒng)一處理
Service.interceptors.request.use((config) => {
    loadingObj = ElLoading.service({
        lock: true,
        text: 'Loading',
        background: 'rgba(0, 0, 0, 0.7)',
    })
    return config;
})


// 相應(yīng)攔截,對返回值做同意處理
Service.interceptors.response.use(response => {
    loadingObj.close();
    const data = response.data;
    if (!data.data) {
        ElMessage.error(data.meta.msg || '服務(wù)器錯誤')
    }
    else {
        ElMessage({
            message: '登錄成功',
            type: 'success',
            duration: 1500
        })
    }
    return response.data;
}, error => {
    loadingObj.close();
    ElMessage({
        message: '服務(wù)器錯誤',
        type: 'error',
        duration: 2000
    })
})

接口的請求

import { get, post } from './service'

// 登錄數(shù)據(jù)請求
export const loginAPI = data => {
    return post({
        url: '/login',
        data
    })

}

總結(jié)

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

相關(guān)文章

  • vant IndexBar實(shí)現(xiàn)的城市列表的示例代碼

    vant IndexBar實(shí)現(xiàn)的城市列表的示例代碼

    這篇文章主要介紹了vant IndexBar實(shí)現(xiàn)的城市列表的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-11-11
  • 報錯[vuex] unknown action type: userLogin問題及解決

    報錯[vuex] unknown action type: userLogin問

    這篇文章主要介紹了報錯[vuex] unknown action type: userLogin問題及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-06-06
  • 不依任何賴第三方,單純用vue實(shí)現(xiàn)Tree 樹形控件的案例

    不依任何賴第三方,單純用vue實(shí)現(xiàn)Tree 樹形控件的案例

    這篇文章主要介紹了不依任何賴第三方,單純用vue實(shí)現(xiàn)Tree 樹形控件的案例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-09-09
  • 詳解Vue如何支持JSX語法

    詳解Vue如何支持JSX語法

    這篇文章主要介紹了詳解Vue如何支持JSX語法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-11-11
  • 基于vue-router 多級路由redirect 重定向的問題

    基于vue-router 多級路由redirect 重定向的問題

    今天小編就為大家分享一篇基于vue-router 多級路由redirect 重定向的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-09-09
  • 一文完全掌握Vue中的$set方法

    一文完全掌握Vue中的$set方法

    這篇文章主要給大家介紹了關(guān)于如何完全掌握Vue中$set方法的相關(guān)資料,vue中$set方法對數(shù)組和對象的處理本質(zhì)上的一樣的,對新增的值添加響應(yīng)然后手動觸發(fā)派發(fā)更新,需要的朋友可以參考下
    2023-11-11
  • vue el-radio單選傳值和默認(rèn)選中方式

    vue el-radio單選傳值和默認(rèn)選中方式

    文章介紹了一個父組件和子組件的交互過程,父組件通過點(diǎn)擊“關(guān)聯(lián)公司”輸入框彈出子組件dialog,子組件中使用SelectCompany.vue實(shí)現(xiàn)默認(rèn)選中功能,作者分享了個人經(jīng)驗(yàn),希望能對大家有所幫助
    2025-01-01
  • vue使用Vue.extend方法仿寫個loading加載中效果實(shí)例

    vue使用Vue.extend方法仿寫個loading加載中效果實(shí)例

    在vue中提供v-loading命令,用于div的loading加載,下面這篇文章主要給大家介紹了關(guān)于vue使用Vue.extend方法仿寫個loading加載中效果的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-06-06
  • Vue中的計算屬性computed傳參方式

    Vue中的計算屬性computed傳參方式

    這篇文章主要介紹了Vue中的計算屬性computed傳參方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-11-11
  • Vue中的匿名插槽與具名插槽詳解

    Vue中的匿名插槽與具名插槽詳解

    這篇文章主要為大家介紹了Vue中的匿名插槽與具名插槽,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2021-12-12

最新評論