Vue實(shí)戰(zhàn)之vue登錄驗(yàn)證的實(shí)現(xiàn)代碼
最近一直在擼一個(gè)給大學(xué)生新生用的產(chǎn)品,在擼的時(shí)候有時(shí)候會(huì)發(fā)現(xiàn)自己力不從心,是不是我的能力下降,是不是我該放棄我的最熱愛的事業(yè)了?這對(duì)我的心靈造成了巨大的傷害,所以我決定向蒼老師起誓一定練好我這雙手——好好寫代碼(想多的同學(xué)趕緊去面壁5秒鐘再過來往下看)~~~
我做的這個(gè)產(chǎn)品是課堂在線編程教學(xué)工具,由于涉及到商業(yè)問題,這里就不能和大家分享了,但是我可以把里面我認(rèn)為很牛(zhuang)X(bi)的技術(shù)和大家分享分享啊。
如果你覺得我寫的很 low的話歡迎加入igeekbar裙里來噴我啊,我在那里等你啊,我相信贊美會(huì)有很多故事喲。哈哈,廢話不多說了,進(jìn)入干貨分享啦~~~
先從登錄分享吧,登錄是我寫完項(xiàng)目后加上的,一開始沒有考慮到登錄問題,后來加的,看了一些人分享的登錄,感覺都太牛逼了(主要我理解能力差看不懂)。最后自己搞了一套。
使用的技術(shù):
- vue
- vue-router
- vuex
首先明確的一點(diǎn)vue是一個(gè)寫但頁面的框架,以前在做登錄的時(shí)候,也許是后端來控制登錄的狀態(tài),把登陸的信息會(huì)放在cookie里。前端也可以做登錄驗(yàn)證的,這主要是基于但頁面引入路由的功能得以實(shí)現(xiàn)的。
在vue-router里有個(gè)鉤子函數(shù) beforeEach (導(dǎo)航守衛(wèi))多霸氣的名字,故名YY就是這是我家沒我的邀請(qǐng)名片都給我滾蛋,還想過來和我一起看蒼老師。beforeEach 接受三個(gè)參數(shù)(to, from, next)分別是to: 小伙要去哪里, from: 小伙從那里來, next: 美女您請(qǐng)進(jìn),小心路滑啊。姑且你們認(rèn)為我寫的很形象啊,如果你感到不服去看 文檔 啊!
理解里 beforeEach 那我們就可以區(qū)搞事情了?;镜乃悸肥牵?/p>
- 我要從router的信息里面拿到 meta 用戶的源信息,如果沒有就讓這屌絲滾蛋,收拾帥氣點(diǎn)再來(也就是去登錄)
- 如果沒有源信息的話,就等跳到 igeekbar 裙里來瞅瞅,拿到入場(chǎng)圈(也就是登錄后拿到了返回結(jié)果并存在router的源信息中,用于之后路由跳轉(zhuǎn)的驗(yàn)證)
寫到這里突然感覺這貌似誰都懂的啊,不管了寫這么多,就當(dāng)你是小白吧(哈哈哈)
下面直接上代碼:
在 router.js 路由中添加一下代碼
// router.js router.beforeEach((to, from, next) => { if (!to.meta.user) { // todo 請(qǐng)求接口獲取數(shù)據(jù) loadUserData().then(user => { // 存放源信息 to.meta.user = user // 存在 vuex 中 store.state.user = user if(user){ next() }else{ next({ path: '/' }) } }) } else { next() } })
統(tǒng)一處理接口的文件api.js
// api.js import axios from 'axios' // 封裝ajax 的 fetch export let fetch = (method, url, data, forceLogin = true) => { return new Promise((resolve, reject) => { axios({ ...data, method: method, url: url }).then(response => { resolve(response.data) }).catch(err => { reject(err) }) }) } // 獲取用戶信息 export let loadUserData = () => { return new Promise((resolve, reject) => { let user = null let cacheKey = 'authUserJsonStr' let authUserJsonStr = sessionStorage.getItem(cacheKey) if (authUserJsonStr) { user = JSON.parse(sessionStorage.getItem(cacheKey)) resolve(user) } else { fetch('GET', '/api/auth_info/', {}, false).then((data) => { user = data sessionStorage.setItem(cacheKey, JSON.stringify(user)) resolve(user) }).catch(() => { resolve(null) }) } }) }
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- Vue 實(shí)現(xiàn)登錄界面驗(yàn)證碼功能
- vue實(shí)現(xiàn)登錄頁面的驗(yàn)證碼以及驗(yàn)證過程解析(面向新手)
- vue 登錄滑動(dòng)驗(yàn)證實(shí)現(xiàn)代碼
- 使用vue-route 的 beforeEach 實(shí)現(xiàn)導(dǎo)航守衛(wèi)(路由跳轉(zhuǎn)前驗(yàn)證登錄)功能
- Vue中的驗(yàn)證登錄狀態(tài)的實(shí)現(xiàn)方法
- vue登錄注冊(cè)及token驗(yàn)證實(shí)現(xiàn)代碼
- vue router+vuex實(shí)現(xiàn)首頁登錄驗(yàn)證判斷邏輯
- Vue中登錄驗(yàn)證成功后保存token,并每次請(qǐng)求攜帶并驗(yàn)證token操作
- vuex + axios 做登錄驗(yàn)證 并且保存登錄狀態(tài)的實(shí)例
- vue實(shí)現(xiàn)登錄時(shí)滑塊驗(yàn)證
相關(guān)文章
解決element-ui?el-drawer抽屜el-dialog彈框關(guān)閉優(yōu)化demo
這篇文章主要為大家介紹了解決element-ui?el-drawer抽屜el-dialog彈框關(guān)閉優(yōu)化demo,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪<BR>2023-06-06Vue項(xiàng)目如何引入bootstrap、elementUI、echarts
這篇文章主要介紹了Vue項(xiàng)目如何引入bootstrap、elementUI、echarts,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-11-11關(guān)于在Vue中import和require的用法分析
在Vue項(xiàng)目中,我們經(jīng)常需要引入外部的模塊或文件,這時(shí)候就會(huì)用到import和require這兩個(gè)關(guān)鍵字,本文將詳細(xì)分析它們的用法,并提供具體的代碼實(shí)例和解釋,需要的朋友可以參考下2023-06-06在vue中使用inheritAttrs實(shí)現(xiàn)組件的擴(kuò)展性介紹
這篇文章主要介紹了在vue中使用inheritAttrs實(shí)現(xiàn)組件的擴(kuò)展性介紹,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-12-12Vue computed實(shí)現(xiàn)原理深入講解
computed又被稱作計(jì)算屬性,用于動(dòng)態(tài)的根據(jù)某個(gè)值或某些值的變化,來產(chǎn)生對(duì)應(yīng)的變化,computed具有緩存性,當(dāng)無關(guān)值變化時(shí),不會(huì)引起computed聲明值的變化。產(chǎn)生一個(gè)新的變量并掛載到vue實(shí)例上去2022-10-10VSCode使React?Vue代碼調(diào)試變得更爽
這篇文章主要為大家介紹了VSCode使React?Vue代碼調(diào)試變得更爽的使用方法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-07-07