重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
这期内容当中小编将会给大家带来有关利用nuxt.js中间件怎么实现拦截权限判断,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。
公司主营业务:网站设计制作、成都网站建设、移动网站开发等业务。帮助企业客户真正实现互联网宣传,提高企业的竞争能力。创新互联是一支青春激扬、勤奋敬业、活力青春激扬、勤奋敬业、活力澎湃、和谐高效的团队。公司秉承以“开放、自由、严谨、自律”为核心的企业文化,感谢他们对我们的高要求,感谢他们从不同领域给我们带来的挑战,让我们激情的团队有机会用头脑与智慧不断的给客户带来惊喜。创新互联推出鱼峰免费做网站回馈大家。项目环境
"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.account, 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',
上述就是小编为大家分享的利用nuxt.js中间件怎么实现拦截权限判断了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注创新互联成都网站设计公司行业资讯频道。
另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。