nuxt.js中间件实现拦截权限判断的方法
网络编程 2021-07-04 16:47www.168986.cn编程入门
这篇文章主要介绍了nuxt.js中间件实现拦截权限判断的方法,长沙网络推广觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随长沙网络推广过来看看吧
最近在把vue的项目改成基于nuxt.js是 ssr渲染,需要进行权限拦截判断,网上查了不少资料。最终看官方手册解决了,贴一下过程
项目环境
"element-ui":"^2.3.4",
"flyio":"^0.5.2",
"js-cookie":"^2.2.0",
"nuxt":"^1.4.0",
一登录页面
在登录页面script中引入
import Cookie from 'js-cookie' //npm install js-cookie --save
在script里加上
data(){ return{ redirectURL:'/' } }, mounted() { let rediretUrl = this.$route.query.ref; if (rediretUrl){ this.redirectURL = rediretUrl } }
接着在methods里面编写一个 submitLogin的方法
submitLogin(ev) { var _this = this; this.$refs.ruleForm2.validate((valid) => { if (valid) { _this.logining = true var sendData = { username: _this.ruleForm2.aount, password: _this.ruleForm2.pass, is_remember: _this.isRemember }; //登录操作 _this.$https.post('login/index', sendData).then(res => { if (res.status == 1) { //将服务端的token存入cookie当中 Cookie.set('token', res.data.token) //返回上一页 _this.$router.push(_this.redirectURL) }else{ _this.$message.warning(res.msg) } }) } else { return false; } }); },
二nuxt中间件middleware编写权限拦截
新建一个userAuth.js,目录结构如下
代码如下
import utils from '~/utils/utils' export default function ({route, req, res, redirect}) { let isClient = process.client; let isServer = process.server; let redirectURL = '/login'; var token, path //在服务端 if (isServer) { let cookies = utils.getcookiesInServer(req) path = req.originalUrl; token = cookies.token ? cookies.token : '' } //在客户端判读是否需要登陆 if (isClient) { token = utils.getcookiesInClient('token') path = route.path; } if (path) { redirectURL = '/login?ref=' + encodeURIComponent(path) } //需要进行权限判断的页面开头 if (!token) { redirect(redirectURL) } }
utils.js里面的方法
import Cookie from 'js-cookie' export default { //获取服务端cookie getcookiesInServer:function (req) { let service_cookie = {}; req && req.headers.cookie && req.headers.cookie.split(';').forEach(function (val) { let parts = val.split('='); service_cookie[parts[0].trim()] = (parts[1] || '').trim(); }); return service_cookie; }, //获取客户端cookie getcookiesInClient:function (key) { return Cookie.get(key) ? Cookie.get(key) : '' } }
到这里,我们的中间件,权限判断依据完成了
三运用到项目中
在项目中。例如,用户信息设置页面,需要进行是否登录判断
pages/user/setting.vue
我们在页面中运用刚刚编写的userAuth中间。
middleware: 'userAuth',
现在
setting页面就有权限判断了
基于nuxt.js渲染的 ssr 网站可以愉快的运行起来了。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持狼蚁SEO。
编程语言
- 宿迁百度关键词排名指南:实现精准营销的关键
- 四川SEO优化怎么做网络推广
- 立昂技术备案老域名收购:如何为您的业务赋能
- 安徽百度关键词seo贵不贵,一般需要多少钱
- 吉林百度快照排名怎么做电话营销
- 多伦新手做SEO怎么做
- 甘肃优化关键词排名推广怎么做论坛营销
- 沙雅SEO网站推广:提升您的在线可见性
- 四川SEO优化如何提升销售额和销售量
- 聂荣网站排名优化:提升网站可见性的全方位指
- 涞水SEO:提升地方企业在线可见性的策略
- 辽宁百度seo排名怎样做网站排名
- 临湘哪有关键词排名优化:提升网站可见度的关
- 黑龙江百度网站优化有没有优惠
- 凉城优化关键词排名推广:提升您的网络可见性
- 萝北整站优化:提升您网站流量和排名的全面指