Nuxt.js是一個建立在Vue.js基礎(chǔ)上的服務(wù)端渲染框架。它非常易于上手并且可以讓你在幾分鐘內(nèi)構(gòu)建你的應(yīng)用。
我們提供的服務(wù)有:網(wǎng)站制作、成都網(wǎng)站建設(shè)、微信公眾號開發(fā)、網(wǎng)站優(yōu)化、網(wǎng)站認證、昆明ssl等。為成百上千企事業(yè)單位解決了網(wǎng)站和推廣的問題。提供周到的售前咨詢和貼心的售后服務(wù),是有科學管理、有技術(shù)的昆明網(wǎng)站制作公司
服務(wù)端渲染是一個解決所有SPA的SEO問題的偉大解決方案,但不幸的是它帶來了另一個問題:權(quán)限驗證成了另一個項目管理中的痛點。
Nuxt.js官網(wǎng)提供了一個稱為“路由鑒權(quán)”的示例(https://nuxtjs.org/examples/auth-routes)。它展示了如何通過一個中間件來限定一個頁面是否可訪問,但是這個檢查是在客戶端的進行的并且服務(wù)端渲染出的內(nèi)容無論是否進行權(quán)限驗證都是一樣的。
那么我們?nèi)绾卧诜?wù)端渲染一個特定的內(nèi)容呢?這里有一個解決方案!
服務(wù)端渲染通常是這樣進行的:客戶端發(fā)起一個請求,例如訪問“/articles/page/1”,服務(wù)端渲染框架訪問一個返回JSON數(shù)據(jù)的API然后生成頁面并將其發(fā)送至客戶端。
我們在這個過程中缺少的是指定一個token或者其他什么來進行權(quán)限驗證的過程?;蛟S一個包含權(quán)限token的Cookie是一個好辦法,它能在頭部被讀取,因此我們的服務(wù)端渲染框架能傳遞它或是把它發(fā)送到API。
首先我們要創(chuàng)建兩個插件:
import axios from 'axios' let options = {}; if (process.SERVER_BUILD) { options.baseURL = `http://api:3030` } let ax = { options, create: (token) => { options.headers = { Authorization: token } return axios.create(ax.options) } } export default ax
這個插件能讓我們通過Axios發(fā)送帶token的請求。
const getCookie = function(cname, req) { let name = cname + "=" let decodedCookie if (typeof window === 'undefined') decodedCookie = decodeURIComponent(req.headers.cookie) else decodedCookie = decodeURIComponent(document.cookie) let ca = decodedCookie.split(';') for(let i = 0; i <ca.length; i++) { let c = ca[i] while (c.charAt(0) == ' ') { c = c.substring(1) } if (c.indexOf(name) == 0) { return c.substring(name.length, c.length) } } return "" } export default getCookie
這一個插件則是從Cookie中獲取token。
接下來你就能在一個“async fetch”方法中簡單地使用它們:
import axios from '~plugins/axios' import getCookie from '~plugins/getCookie' export default { async fetch ({ store, isServer, req, redirect }) { if(isServer) { const ax = axios.create(getCookie('token', req)) try { let { data } = await ax.get('/populate') if(data.store && data.store.user) store.commit('user/setData', data.store.user) else redirect('/login') } catch(e) {} } } }
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。
網(wǎng)頁標題:Nuxt.jsSSR與權(quán)限驗證的實現(xiàn)
網(wǎng)頁鏈接:http://jinyejixie.com/article16/gpsddg.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站收錄、網(wǎng)站改版、、靜態(tài)網(wǎng)站、小程序開發(fā)、電子商務(wù)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)