news 2026/5/21 13:40:31

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/5/16 18:21:07

Claude Code 小白指北(二):五个“暗号”,让 Claude Code 干活更听话

上篇文章我们将 Claude Code 给用起来了,只要像聊天那样,把我们的想要做的事情告诉他,它就能吭哧吭哧的把活给我们干好。 但是…不知道小伙伴们用着用着,有没有发现它也有些小问题。 Claude Code 这家伙有时候过于热情&#xff0c…

作者头像 李华
网站建设 2026/5/21 13:40:04

好写作AI:当你脑中有匹野马,AI帮你建个专业赛马场

导语:如果你的学术灵感像烟花般绚烂,落到纸上却像哑炮 这画面是不是很熟悉: 组会时你滔滔不绝三十分钟,导师说“想法挺好,写出来看看” 深夜灵光乍现,在备忘录里写下十行天才构想 一周后打开文档&#x…

作者头像 李华
网站建设 2026/5/21 13:39:48

定稿前必看!千笔·专业学术智能体,继续教育论文写作神器

你是否曾在论文写作中感到力不从心?选题无从下手,框架反复调整,查重率屡屡超标,格式问题层出不穷……这些困扰让无数学生在毕业季倍感焦虑。面对学术写作的重重挑战,你是否渴望一款真正懂你的智能助手?千笔…

作者头像 李华
网站建设 2026/5/20 10:00:29

【C/C++】Order Book实现

订单簿(Order Book):从原理到工业级实现 什么是订单簿 订单簿(Order Book)是交易所撮合引擎(Matching Engine)的核心数据结构。它维护着市场上所有未成交的限价单(Limit Order&#…

作者头像 李华
网站建设 2026/5/21 12:44:28

【期货量化进阶】期货量化交易中的情绪分析(实战技巧)

一、前言 市场情绪是影响价格波动的重要因素。通过分析市场情绪,可以更好地理解市场行为,提高策略的准确性。本文将介绍如何量化分析市场情绪并应用于交易策略。 本文将介绍: 市场情绪指标情绪数据获取情绪分析方法情绪交易策略情绪监控系…

作者头像 李华
网站建设 2026/4/27 8:21:23

【期货量化实战】如何选择适合的期货品种进行量化交易(选品指南)

一、前言 选择合适的期货品种是量化交易成功的第一步。不同品种有不同的特性,适合不同的策略。本文将详细介绍如何选择适合的期货品种进行量化交易。 本文将介绍: 品种选择标准品种特性分析流动性评估相关性分析品种组合选择 二、为什么选择天勤量化…

作者头像 李华