Vue驾校-从项目学Vue-6

前言:

往期Vue框架内容:Vue驾校-从项目学Vue-1
算法系列博客友链:神机百炼
强烈推荐Y总所有课程:小白友好的程序教学社区

项目实战5:

1. 登录组件:

1. 按钮表单调用全局变量Vuex中的函数:

在store中mutations或actions实现函数:
  • 函数参数context用于传递API,data用于传递自定义信息:
    自定义函数
组件中useStore().dispatch()调用函数:
  • useStore().dispatch(“vuex中的函数名”,{对象参数})
    组件调用vuex函数
查看前端调用vuex函数效果:
  • API网址:https://app165.acapp.acwing.com.cn/api/token/
    这个用于获取JWT令牌和公钥的网址有点不靠谱…
  • 如果你运气比较好,点击一次登录按钮就能在控制台看到一条refresh和access:
    Base64版本的JWT
  • 如果你运气不好,可能和我一样,一直显示浏览器CORS禁止跨域:
    CORS问题
  • 如果你一天一直CORS禁止跨域,不妨尝试将用户名密码设置简单一些,直接123123。而且不要让浏览帮你用历史记录填写用户名和密码
  • 但是其实这一步能不能看到含有refresh和access的reps无所谓,不影响下面

2, jwt_decode(JWT令牌)解码:

  • 用户信息在登录时存储到了resp中的JWT令牌中,我们需要安装对resp解码的包:
    jwt-decode
  • 在login函数中调用jwt_decode()函数解码jwt令牌:
    解码函数
  • 前端查看解码结果:用户名密码最好简单一些
    jwt-decode结果

3, 获取登录时提交的用户信息:

  • ajax调用已有的API:https://app165.acapp.acwing.com.cn/myspace/getinfo/,来获取登录用户的详细信息:

API调用

  • 前端查看用户登录的信息:
    用户的登录信息

4, 更新登录后的Vuex全局变量:

确定全局变量该有的属性:
  • 确定我们登录后要使用的用户信息,全部以属性加入到全局变量对象中:
    要用到的用户信息
配套同步函数修改全局变量
  • 在mutations中构建专门用于修改变量值的同步函数
    同步函数
调用API为全局变量提供数据
  • ajax调用API获取登录时提交给JWT的信息:https://app165.acapp.acwing.com.cn/myspace/getinfo/

    cotext.commit(调用mutations中的函数名),对,下图中不小心多打了个m
    修改全局变量vuex

  • 前端网页登录,查看是否将登录信息成功传递给vuex全局变量:
    全局变量修改成功

  • 如果获取JWT就失败,也应该回调登录页面设置的报错函数:
    回调失败函数

4, 定时刷新登录access:

  • 定期刷新access的方法有两种:一种是每次请求都检查一下access是否过期,还有一种不经过访问时间到了就刷新
  • 本项目采用第二种,而且由于一个access本身保留时长5min,为了避免边界情况,我们每次4min30s就刷新
  • 刷新JWT的API:https://app165.acapp.acwing.com.cn/api/token/refresh/
  • 先设置刷新时间1s,查看网页反应:
    刷新正常
  • 现在更新Vuex中全局变量的refresh变量:
    更新变量

5. 登录成功后网页跳转:

  • 使用router.push(name:‘组件名’);跳转到目标页面:
    router.push()

  • 前端网页查看效果:
    先输入一个JWT中错误的密码看看:
    密码错误

  • 再输入JWT中正确的密码:
    成功跳转到目标页面

  • 可能有人好奇,没注册是怎么登录的?
    我们单纯获取JWT的API没有设置验证,但是调用获取JWT中的用户登录信息API设置了验证
    我们在没有获取登录信息时已经为用户名123密码123注册了JWT和公钥
    之后的验证和刷新都是用户名密码不变,赋予新的私钥,计算新的公钥
    也就是说在未设置验证的时候我们已经产生了私钥和公钥,且之后验证或者刷新access时也只改变私钥和公钥,我们只负责正确的用户名密码即可

2. 导航栏组件:

1. 登录成功显示用户名和退出:

存储信息到vuex:
  • 先useStore().dispatch(“actions”.{参数对象}),再context.commit(“mutations”)来将数据存储到vuex中
  • 也可以直接useStore.commit(“matations中函数”,{参数对象});来直接存储
取出vuex中信息:
  • 组件在<\temple>和<\script>部分中,直接使用**$store.state.对象.属性**,来取出vuex中的值
为NavBar添加v-if:
  • 登录成功后导航栏从”登录+注册“,变为”用户名+退出“,这用到了vue提供的v-if & v-else:
    选择性显示
实现退出功能:
  • JWT维护登录机制 和 Session维护登录机制有很大不同:

    前者自己销毁获得的JWT令牌即可,后者要把useid一项从数据库删除

    也就是前者退出登录无需访问服务器,后者需要访问服务器

  • 现在为退出标签绑定撕毁JWT令牌即修改vuex全局变量的事件函数即可:
    退出函数

  • 查看网页点击退出后的反应:
    真不错

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

starnight531

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值