在現(xiàn)代的web應(yīng)用中,用戶的登錄狀態(tài)儲(chǔ)存在服務(wù)器端,每一次請(qǐng)求都需要告訴服務(wù)器當(dāng)前用戶的身份,這就需要使用token。Vue作為一種流行的前端框架,同樣需要使用token來實(shí)現(xiàn)用戶認(rèn)證。在Vue的登錄頁(yè)面中,我們可以通過使用axios庫(kù)從服務(wù)器端獲取token,然后將token存儲(chǔ)到本地,每一次請(qǐng)求都附帶token,以保證用戶認(rèn)證。
axios.post('/api/login', { username: 'myusername', password: 'mypassword' }).then(response =>{ localStorage.setItem('token', response.data.token) })
上述代碼示例中,我們通過發(fā)送POST請(qǐng)求到服務(wù)器端獲取token。獲取到的token被存儲(chǔ)到localStorage中,以便在后續(xù)的請(qǐng)求中使用。
在Vue中,我們可以使用Vue Router來實(shí)現(xiàn)路由跳轉(zhuǎn)。在跳轉(zhuǎn)路由的時(shí)候,我們需要在請(qǐng)求頭中添加token:
import axios from 'axios' import router from './router' axios.interceptors.request.use( config =>{ const token = localStorage.getItem('token') if(token) { config.headers.Authorization = 'Bearer ' + token } return config }, error =>{ return Promise.reject(error) } ) router.beforeEach((to, from, next) =>{ const requiresAuth = to.matched.some(record =>record.meta.requiresAuth) const token = localStorage.getItem('token') if(requiresAuth && !token) { next('/login') } else { next() } })
在上述代碼中,我們使用axios的攔截器來為請(qǐng)求添加token。在攔截器中,我們首先從localStorage中獲取token,然后為請(qǐng)求添加Authorization頭,并在前面加上"Bearer "。
同時(shí),在路由跳轉(zhuǎn)前,我們需要驗(yàn)證用戶是否已經(jīng)登錄。如果用戶未登錄并且跳轉(zhuǎn)的路由需要認(rèn)證,那么我們就要將用戶重定向到登錄頁(yè)面。這里需要注意的是,我們?cè)诼酚啥x中需要添加meta字段,并設(shè)置requiresAuth為true才能使頁(yè)面需要認(rèn)證。
除了使用localStorage來儲(chǔ)存token外,我們也可以使用cookie或sessionStorage來儲(chǔ)存token。使用cookie的好處在于可以跨域使用,但是cookie的大小有限制;而使用sessionStorage的好處在于可以在瀏覽器關(guān)閉后自動(dòng)刪除存儲(chǔ)的信息。
總的來說,Vue登錄頁(yè)面的token認(rèn)證實(shí)現(xiàn)并不難,關(guān)鍵在于對(duì)路由的處理。每一次向服務(wù)器端發(fā)送請(qǐng)求時(shí),都要為請(qǐng)求頭添加token,以保證用戶認(rèn)證的有效性。同時(shí),也需要對(duì)用戶的登錄狀態(tài)進(jìn)行驗(yàn)證,并且在需要認(rèn)證的頁(yè)面中跳轉(zhuǎn)到登錄頁(yè)面。