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

nuxt 自定義 auth 中間件實(shí)現(xiàn)令牌的持久化操作

 更新時(shí)間:2020年11月05日 09:48:36   作者:xiao_fei_blog  
這篇文章主要介紹了nuxt 自定義 auth 中間件實(shí)現(xiàn)令牌的持久化操作,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧

核心點(diǎn)就是在process.server下,把之前存在 cookie 中的數(shù)據(jù)再用store.commit一下

auth.js

/* eslint-disable no-unused-vars */
/* eslint-disable no-useless-return */

export const TokenKey = 'Admin-token'

/**
 * 解析服務(wù)端拿到的cookie
 * @param {*} cookie
 * @param {*} key
 */
export function getCookie(cookie, key) {
 if (!cookie) return
 const arrstr = cookie.split('; ')
 for (let i = 0; i < arrstr.length; i++) {
 const temp = arrstr[i].split('=')

 if (temp[0] === key) return unescape(temp[1])
 }
}

// 登錄頁
const loginPath = '/login'
// 首頁
const indexPath = '/home'
// 路由白名單,直接繞過路由守衛(wèi)
const whiteList = [loginPath]

/**
 * @description 鑒權(quán)中間件,用于校驗(yàn)登陸
 *
 */
export default async ({ store, redirect, env, route, req }) => {
 const { path, fullPath, query } = route
 const { redirect: redirectPath } = query

 // 應(yīng)對刷新 vuex狀態(tài)丟失的解決方案
 if (process.server) {
 const cookie = req.headers.cookie
 const token = getCookie(cookie, TokenKey)

 // 設(shè)置登錄狀態(tài)
 if (token) {
  store.commit('LOGIN', token) //'LOGIN' 和store中的mutations對應(yīng)起來就可以了
 }

 if (token) {
  // 已經(jīng)登錄,進(jìn)來的是登錄頁,且有重定向的路徑,直接調(diào)跳到重定向的路徑
  if (path === loginPath && path !== redirectPath) {
  redirect(redirectPath)
  } else if (path === '/') {
  redirect(indexPath)
  } else {
  // 其他的已經(jīng)登錄過得直接跳過
  return
  }
 } else {
  // 鑒權(quán)白名單
  if (whiteList.includes(path)) return

  // 未登錄,進(jìn)來的不是是登錄頁,全部重定向到登錄頁
  if (!path.includes(loginPath)) {
  redirect(`${loginPath}?redirect=${encodeURIComponent(fullPath)}`)
  }
 }
 }
}

補(bǔ)充知識:NUXT 中間件 Middleware

中間件可以使您的自定義的函數(shù)在渲染頁面之前運(yùn)行

所有的中間件都必須放置在middleware/目錄下。文件名將作為中間件的名稱(如:middleware/auth將成為中間件auth)。

中間件收到上下文作為第一個(gè)參數(shù):

export default function (context) {
 context.userAgent = context.isServer ? context.req.headers['user-agent'] : navigator.userAgent
}

中間件將按照此順序在序列中執(zhí)行:

1、nuxt.config.js

2、匹配的布局

3、匹配的頁面

中間件可以是異步的,僅返回一個(gè)Promise或者使用第二個(gè)callback返回值:

middleware/stats.js

import axios from 'axios' 
export default function ({ route }) {
 return axios.post('http://my-stats-api.com', {
 url: route.fullPath
 })
}

然后,在nuxt.config.js,布局或者頁面中,配置middleware參數(shù)

nuxt.config.js

module.exports = {
 router: {
 middleware: 'stats'
 } 
}

中間件stats將在每次路由改變時(shí)被調(diào)用。

想了解中間件的例子,請移步example-auth0

以上這篇nuxt 自定義 auth 中間件實(shí)現(xiàn)令牌的持久化操作就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • 關(guān)于vue文件中index.vue的使用方法

    關(guān)于vue文件中index.vue的使用方法

    這篇文章主要介紹了關(guān)于vue文件中index.vue的使用方法,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-10-10
  • 茶余飯后聊聊Vue3.0響應(yīng)式數(shù)據(jù)那些事兒

    茶余飯后聊聊Vue3.0響應(yīng)式數(shù)據(jù)那些事兒

    這篇文章主要介紹了茶余飯后聊聊Vue3.0響應(yīng)式數(shù)據(jù)那些事兒,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-10-10
  • vue頁面params傳值的坑及解決

    vue頁面params傳值的坑及解決

    這篇文章主要介紹了vue頁面params傳值的坑及解決方案,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-05-05
  • 如何在Vue中使用debouce防抖函數(shù)

    如何在Vue中使用debouce防抖函數(shù)

    本文主要介紹在Vue中使用debouce防抖函數(shù),設(shè)置一個(gè)門檻值,表示兩次?Ajax?通信的最小間隔時(shí)間。如果在間隔時(shí)間內(nèi),發(fā)生新的keydown事件,則不觸發(fā)?Ajax?通信,并且重新開始計(jì)時(shí)。如果過了指定時(shí)間,沒有發(fā)生新的keydown事件再將數(shù)據(jù)發(fā)送出去,這便是debouce防抖函數(shù)
    2021-12-12
  • Vue中使一個(gè)div鋪滿全屏的實(shí)現(xiàn)

    Vue中使一個(gè)div鋪滿全屏的實(shí)現(xiàn)

    最近在項(xiàng)目開發(fā)中,就遇到了這個(gè)問題,Vue中如何使一個(gè)div鋪滿全屏,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2024-07-07
  • vue中的vue-router?query方式和params方式詳解

    vue中的vue-router?query方式和params方式詳解

    這篇文章主要介紹了vue中的vue-router?query方式和params方式,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • Vue 實(shí)現(xiàn)樹形視圖數(shù)據(jù)功能

    Vue 實(shí)現(xiàn)樹形視圖數(shù)據(jù)功能

    這篇文章主要介紹了Vue 實(shí)現(xiàn)樹形視圖數(shù)據(jù)功能,利用簡單的樹形視圖實(shí)現(xiàn)的,在實(shí)現(xiàn)過程中熟悉了組件的遞歸使用,感興趣的朋友跟隨腳本之家小編一起學(xué)習(xí)吧
    2018-05-05
  • 教你60行代碼實(shí)現(xiàn)一個(gè)迷你響應(yīng)式系統(tǒng)vue

    教你60行代碼實(shí)現(xiàn)一個(gè)迷你響應(yīng)式系統(tǒng)vue

    這篇文章主要為大家介紹了教你60行代碼實(shí)現(xiàn)一個(gè)迷你響應(yīng)式系統(tǒng)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪<BR>
    2023-03-03
  • vue實(shí)現(xiàn)打包添加二級目錄

    vue實(shí)現(xiàn)打包添加二級目錄

    這篇文章主要介紹了vue實(shí)現(xiàn)打包添加二級目錄方式,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-07-07
  • Object.assign觸發(fā)watch原理示例解析

    Object.assign觸發(fā)watch原理示例解析

    這篇文章主要為大家介紹了Object.assign觸發(fā)watch原理示例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-11-11

最新評論