news 2026/4/18 3:10:16

RBAC前端架构-06:使用localstorage及Vuex用户信息存储逻辑

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
RBAC前端架构-06:使用localstorage及Vuex用户信息存储逻辑

1-文件调整

  1. 修改frontend-vue2\src\store\index.js,用于整体整合Vuex更简洁
importVuefrom"vue";importVuexfrom"vuex";// 标签页管理模块importtabsfrom"./modules/tabs";// 用户信息管理模块importuserfrom"./modules/user";Vue.use(Vuex);// 创建并导出 Vuex store 实例exportdefaultnewVuex.Store({// 模块化配置 - 将 store 分割成不同的模块modules:{// 所有user的commit/dispatch都要加命名空间,如: this.$store.dispatch("user/logout");user,// 后续扩展...},});
  1. 新增frontend-vue2\src\store\modules\user.js,用于控制用户相关的信息,结合localstorage,配合Vuex存储用户的token,基本信息,菜单,权限信息,后续便于其他地方使用
import{loginApi,logoutApi}from"@/api/auth";import{getCurrentUserMenus,getUserInfo}from"@/api/user";importVuefrom"vue";importVuexfrom"vuex";Vue.use(Vuex);// 页面刷新时从 localStorage 里恢复用户状态constsavedToken=localStorage.getItem("token");constsavedUserInfo=localStorage.getItem("userInfo");constsavedUserMenus=localStorage.getItem("userMenus");constsavedUserPermissions=localStorage.getItem("userPermissions");conststate={// 全局状态:存储用户 tokentoken:savedToken||null,// 用户信息userInfo:savedUserInfo?JSON.parse(savedUserInfo):null,// 全局loading信息,用于调用接口时显示 loadingloading:false,// 当前用户的权限码userPermissions:savedUserPermissions?JSON.parse(savedUserPermissions):[],// 当前用户的菜单树userMenus:savedUserMenus?JSON.parse(savedUserMenus):[],};// mutations:修改state的唯一入口constmutations={// 设置 token(登录时调用)setToken(state,token){state.token=token;localStorage.setItem("token",token);},// 清除 token(退出时调用)clearToken(state){state.token=null;localStorage.removeItem("token");},// 设置用户信息setUserInfo(state,userInfo){state.userInfo=userInfo;localStorage.setItem("userInfo",JSON.stringify(userInfo));},// 清除用户信息clearUserInfo(state){state.userInfo=null;localStorage.removeItem("userInfo");},setUserPermissions(state,userPermissions){state.userPermissions=userPermissions;localStorage.setItem("userPermissions",JSON.stringify(userPermissions));},clearUserPermissions(state){state.userPermissions=[];localStorage.removeItem("userPermissions");},setUserMenus(state,userMenus){state.userMenus=userMenus;localStorage.setItem("userMenus",JSON.stringify(userMenus));},clearUserMenus(state){state.userMenus=[];localStorage.removeItem("userMenus");},// 控制 loading 显示开关setLoading(state,flag){state.loading=flag;},};// actions:处理异步逻辑(像 Java Service 层)constactions={asynclogin({commit},{username,password}){try{// 登录获取tokenconstres=awaitloginApi({username,password});// 登录失败,抛错if(res.code!=="200"){thrownewError(res.message||"登录失败");}commit("setToken",res.data);// 登录成功后获取用户信息constuserInfo=awaitgetUserInfo();commit("setUserInfo",userInfo.data);// 登录成功后获取用户权限// TODO可以拆一个权限接口commit("setUserPermissions",userInfo.data.permissions||[]);// 登录成功后获取用户的菜单信息constuserMenus=awaitgetCurrentUserMenus();commit("setUserMenus",userMenus.data||[]);}catch(err){throwerr;}},// 退出登录asynclogout({commit},skipApiCall=false){try{commit("setLoading",true);// 只有在主动触发 logout 时才调用 APIif(!skipApiCall){awaitlogoutApi();}}catch(error){console.error("Logout API error:",error);}finally{commit("clearToken");commit("clearUserInfo");commit("clearUserMenus");commit("clearUserPermissions");commit("setLoading",false);}},};// getters:数据的派生计算constgetters={// 获取登录状态:是否有 tokenisLoggedIn:(state)=>!!state.token,// 获取用户信息userInfo:(state)=>state.userInfo,// 获取用户角色roles:(state)=>state.userInfo?.roles||[],// 获取用户权限permissions:(state)=>state.userPermissions||[],// 检查是否有某个权限hasPermission:(state)=>(permission)=>{returnstate.userPermissions?.includes(permission)||false;},// 检查是否有某个角色hasRole:(state)=>(role)=>{returnstate.userInfo?.roles?.includes(role)||false;},// 获取用户菜单userMenus:(state)=>state.userMenus||[],// 页面loading状态isLoading:(state)=>state.loading,};// 导出这个 Vuex 模块的配置exportdefault{// 开启命名空间,防止不同模块间的状态冲突namespaced:true,state,mutations,actions,getters,};

主要作用:

  • 状态管理 (State): 存储token、用户信息、权限列表、菜单树以及全局加载状态。
  • 持久化: 初始化时自动从localStorage读取数据,更新时同步写入,确保页面刷新后登录状态不丢失
  • 异步流 (Actions): 封装了复杂的登录逻辑(登录 -> 获取用户信息 -> 获取菜单/权限)和登出逻辑。
  • 数据派生 (Getters): 提供快捷的权限判断方法(如hasPermission),方便在组件中直接使用

2-结构展示

获取对应接口响应的信息,然后存储

  • token:
eyJhbGciOiJIUzI1NiJ9.eyJzdWIiOiIxIiwiaWF0IjoxNzcwNzc3OTYwLCJleHAiOjE3NzA4NjQzNjB9.GxtIfTMJ_fot4VodLEdQPFeFuiTZ-PQWHfo0dN6GVco
  • userInfo:
{"id":1,"username":"admin","nickname":"管理员Main","email":"999999999@qq.com","phone":"13983999999","status":1,"createTime":"2025-09-23T07:19:52","updateTime":"2026-01-23T08:17:59","roles":["ADMIN"],"permissions":["btn:user:system:menu:create","btn:user:system:menu:delete","btn:permission:assign","btn:user:create","btn:user:update","btn:user:delete","btn:user:list"]}
  • userMenus:
[{"id":5,"menuName":"系统管理","menuCode":"menu:user:system","menuType":1,"parentId":null,"path":"/system","component":"","icon":"","sortOrder":0,"status":1,"createTime":"2025-10-24T03:58:06","updateTime":"2025-10-31T08:56:10","children":[{"id":4,"menuName":"个人中心","menuCode":"menu:user:system:profile","menuType":1,"parentId":5,"path":"/system/profile","component":"Profile","icon":"user","sortOrder":0,"status":1,"createTime":"2025-10-24T03:58:06","updateTime":"2025-10-31T08:55:57","children":[]},{"id":6,"menuName":"权限分配","menuCode":"menu:user:system:permissionassign","menuType":1,"parentId":5,"path":"/system/permissionsAssign","component":"PermissionsAssign","icon":"","sortOrder":0,"status":1,"createTime":null,"updateTime":"2025-11-19T07:01:24","children":[]},{"id":1,"menuName":"用户管理","menuCode":"menu:user:system:user","menuType":1,"parentId":5,"path":"/system/user","component":"UserManagement","icon":"user","sortOrder":1,"status":1,"createTime":"2025-10-24T03:58:06","updateTime":"2025-10-31T08:55:57","children":[]},{"id":3,"menuName":"菜单管理","menuCode":"menu:user:system:menu","menuType":1,"parentId":5,"path":"/system/menu","component":"MenuManagement","icon":"setting","sortOrder":3,"status":1,"createTime":"2025-10-24T03:58:06","updateTime":"2025-10-31T08:55:57","children":[]}]},{"id":2,"menuName":"订单管理","menuCode":"menu:order","menuType":1,"parentId":null,"path":"/order","component":"OrderManagement","icon":"tickets","sortOrder":2,"status":1,"createTime":"2025-10-24T03:58:06","updateTime":"2025-10-30T04:18:39","children":[]}]
  • userPermissions:
["btn:user:system:menu:create","btn:user:system:menu:delete","btn:permission:assign","btn:user:create","btn:user:update","btn:user:delete","btn:user:list"]

以上信息主要用于让其他组件获取使用,比如后续菜单的展示,就用userMenus中的信息

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/17 22:07:44

如何将文件从 PC 无线传输到 Android

如果您需要将文件从 PC 无线传输到 Android,有很多无线选项可供选择。然而,并非所有选项都安全可靠。为了帮助您无需 USB 数据线即可安全地发送文件,我们在本文中总结了 7 种方法和 3 个必知常见问题解答。如果您需要,请继续阅读。…

作者头像 李华
网站建设 2026/4/17 20:00:38

Qt之多线程和并发_P4

本节主要介绍线程死锁,会从三个方面介绍:什么是线程死锁、死锁产生的条件和原因分析、死锁的规避,并配有示例程序详细分析死锁的原因和解决方案。 文章目录 线程死锁的概念 什么叫死锁 死锁条件 死锁示例 场景1:重复锁定同一个互斥量 场景2:递归调用 场景3:锁顺序反转 场…

作者头像 李华
网站建设 2026/4/18 6:43:47

好写作AI:收到评审意见后,让AI帮你把“重投”变成“接收”

导语:当邮箱弹出“Decision: Major Revision”时,你的心跳是不是漏了一拍?每个投过稿的硕博生都懂那种感觉:打开评审意见前,需要做十分钟心理建设看到“建议拒绝”时,大脑瞬间空白三秒面对二十条修改意见&a…

作者头像 李华
网站建设 2026/4/17 15:31:06

DOS叙事环与意义行为原生论:智能时代意义生成的重构、责任伦理的奠基与人机共生愿景的导航

DOS叙事环与意义行为原生论:智能时代意义生成的重构、责任伦理的奠基与人机共生愿景的导航摘要本文旨在对岐金兰提出的“AI元人文”核心理论——“DOS叙事环”与“意义行为原生论”——进行一次全面、深入且非简化性的系统性阐释。面对智能时代日益凸显的算法介入、…

作者头像 李华
网站建设 2026/4/18 6:43:37

AI浪潮来袭!小白程序员如何抓住高薪算法岗机遇?收藏必备!

AI技术正席卷后端领域,传统岗位缩减,AI岗位需求激增,年薪可达40万。然而,许多求职者因能力不匹配而难以胜任。为帮助大家转型,推出深度算法培养计划,由一线大厂专家授课,涵盖实战项目&#xff0…

作者头像 李华
网站建设 2026/4/18 6:41:32

企业考试系统哪家好?2026实测指南+避坑攻略

在企业数字化管理进程中,企业考试系统已成为员工考核、技能测评、合规培训的核心工具。但面对市面上五花八门的产品,很多企业管理者都会陷入迷茫:选贵的怕不值,选便宜的怕踩坑,选功能多的怕用不上,选简单的…

作者头像 李华