码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Vue驾校-从项目学Vue-6


    Vue驾校-从项目学Vue-6

    • 前言:
    • 项目实战5:
      • 1. 登录组件:
        • 1. 按钮表单调用全局变量Vuex中的函数:
          • 在store中mutations或actions实现函数:
          • 组件中useStore().dispatch()调用函数:
          • 查看前端调用vuex函数效果:
        • 2, jwt_decode(JWT令牌)解码:
        • 3, 获取登录时提交的用户信息:
        • 4, 更新登录后的Vuex全局变量:
          • 确定全局变量该有的属性:
          • 配套同步函数修改全局变量
          • 调用API为全局变量提供数据
        • 4, 定时刷新登录access:
        • 5. 登录成功后网页跳转:
      • 2. 导航栏组件:
        • 1. 登录成功显示用户名和退出:
          • 存储信息到vuex:
          • 取出vuex中信息:
          • 为NavBar添加v-if:
          • 实现退出功能:

    前言:

    往期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全局变量的事件函数即可:
      退出函数

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

  • 相关阅读:
    Spring注解驱动之ServletContainerInitializer使用
    算法基础之二分查找
    100-centos 安装mysql
    No qualifying bean of type 问题
    SPARKSQL3.0-SessionState构建源码剖析
    天猫淘宝卡券包演进史
    EasyExcel 注解fillForegroundColor
    pycharm创建的虚拟环境为什么用conda env list命令查询不到?
    实际项目中如何进行问题排查
    前端性能优化——启用文本压缩
  • 原文地址:https://blog.csdn.net/buptsd/article/details/125813887
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号