ruoyi-app前端在缓存中添加nick_name和user_id属性值

devtools/2024/11/15 1:36:45/

在这里插入图片描述

需求

ruoyi-app原生自带只有avatar、name、roles、permissions;在显示中,我们大多数需要nick_name、user_id;当然获取方式也可以通过name去调用接口查询,但我想偷个懒。

代码

代码已经调好的,复制即用;至于修改点,细心一点应该能自己发现

1、修改 store/modules/user.js 文件

import config from '@/config'
import storage from '@/utils/storage'
import constant from '@/utils/constant'
import { login, logout, getInfo } from '@/api/login'
import { getToken, setToken, removeToken } from '@/utils/auth'const baseUrl = config.baseUrlconst user = {state: {token: getToken(),name: storage.get(constant.name),userId: storage.get(constant.userId),nickName: storage.get(constant.nickName),avatar: storage.get(constant.avatar),roles: storage.get(constant.roles),permissions: storage.get(constant.permissions)},mutations: {SET_TOKEN: (state, token) => {state.token = token},SET_NAME: (state, name) => {state.name = namestorage.set(constant.name, name)},SET_USER_ID: (state, userId) => {state.userId = userIdstorage.set(constant.userId, userId)},SET_NICK_NAME: (state, nickName) => {state.nickName = nickNamestorage.set(constant.nickName, nickName)},SET_AVATAR: (state, avatar) => {state.avatar = avatarstorage.set(constant.avatar, avatar)},SET_ROLES: (state, roles) => {state.roles = rolesstorage.set(constant.roles, roles)},SET_PERMISSIONS: (state, permissions) => {state.permissions = permissionsstorage.set(constant.permissions, permissions)}},actions: {// 登录Login({ commit }, userInfo) {const username = userInfo.username.trim()const password = userInfo.passwordconst code = userInfo.codeconst uuid = userInfo.uuidreturn new Promise((resolve, reject) => {login(username, password, code, uuid).then(res => {setToken(res.token)commit('SET_TOKEN', res.token)resolve()}).catch(error => {reject(error)})})},// 获取用户信息GetInfo({ commit, state }) {return new Promise((resolve, reject) => {getInfo().then(res => {const user = res.userconst avatar = (user == null || user.avatar == "" || user.avatar == null) ? require("@/static/images/profile.jpg") : baseUrl + user.avatarconst username = (user == null || user.userName == "" || user.userName == null) ? "" : user.userNameconst userId = (user == null || user.userId == "" || user.userId == null) ? "" : user.userIdconst nickName = (user == null || user.nickName == "" || user.nickName == null) ? "" : user.nickNameif (res.roles && res.roles.length > 0) {commit('SET_ROLES', res.roles)commit('SET_PERMISSIONS', res.permissions)} else {commit('SET_ROLES', ['ROLE_DEFAULT'])}commit('SET_NAME', username)commit('SET_USER_ID', userId)commit('SET_NICK_NAME', nickName)commit('SET_AVATAR', avatar)resolve(res)}).catch(error => {reject(error)})})},// 退出系统LogOut({ commit, state }) {return new Promise((resolve, reject) => {logout(state.token).then(() => {commit('SET_TOKEN', '')commit('SET_ROLES', [])commit('SET_PERMISSIONS', [])removeToken()storage.clean()resolve()}).catch(error => {reject(error)})})}}
}export default user

2、修改 store/getter.js 文件

const getters = {token: state => state.user.token,avatar: state => state.user.avatar,name: state => state.user.name,userId: state => state.user.userId,nickName: state => state.user.nickName,roles: state => state.user.roles,permissions: state => state.user.permissions
}
export default getters

3、修改 utils/storage.js 文件

import constant from './constant'// 存储变量名
let storageKey = 'storage_data'// 存储节点变量名
let storageNodeKeys = [constant.avatar, constant.name,constant.userId,constant.nickName, constant.roles, constant.permissions]const storage = {set: function(key, value) {if (storageNodeKeys.indexOf(key) != -1) {let tmp = uni.getStorageSync(storageKey)tmp = tmp ? tmp : {}tmp[key] = valueuni.setStorageSync(storageKey, tmp)}},get: function(key) {let storageData = uni.getStorageSync(storageKey) || {}return storageData[key] || ""},remove: function(key) {let storageData = uni.getStorageSync(storageKey) || {}delete storageData[key]uni.setStorageSync(storageKey, storageData)},clean: function() {uni.removeStorageSync(storageKey)}
}export default storage

4、修改 utils/constant.js 文件

const constant = {avatar: 'vuex_avatar',name: 'vuex_name',userId: 'vuex_user_id',nickName: 'vuex_nick_name',roles: 'vuex_roles',permissions: 'vuex_permissions'}export default constant

http://www.ppmy.cn/devtools/100756.html

相关文章

调用ragflow api实现俩个模型根据知识库的内容来进行对话 简易版

调用ragflow接口实现俩个模型对话 简易版 用到的库流程代码参考文献 用到的库 requests 调用api 发送请求streamlit 做一个简单的页面json 解析接口返回的内容 流程 根据ragflow官方api文档中的内容,我们需要先将api键需要放到请求头中,然后再调用new…

量子计算与未来的渗透技术(壹)

第一篇:量子计算对渗透测试的潜在影响 1. 量子计算概述 量子计算的基本原理:介绍量子比特(qubits)、叠加态、纠缠态等量子计算的核心概念。量子计算对传统计算的优势:解释量子计算在处理复杂计算任务上的潜在优势&am…

ASP.NET Core 入门教程一 创建最小 API

构建最小 API,以创建具有最小依赖项的 HTTP API。 它们非常适合需要在 ASP.NET Core 中仅包括最少文件、功能和依赖项的微服务和应用。 本教程介绍使用 ASP.NET Core 生成最小 API 的基础知识。 启动 Visual Studio 2022 并选择“创建新项目”。 在“创建新项目”…

阿里云ubuntu系统安装jdk + tomcat

一、安装配置JDK 1.下载安装包 1.1安装地址 https://www.oracle.com/cn/java/technologies/downloads/ 注意: 下载的时间需要有oracle账号,可以注册;我们下载的是JDK8版本; 2.压缩文件传输到linux上面 2.1采用的为Xftp软件传…

windows核心编程 内核对象,创建进程(CreateProcess),管道(CreatePipe)

windows核心编程 内核对象,创建进程(CreateProcess),管道(CreatePipe) windows核心编程 内核对象,创建进程(CreateProcess),管道(CreatePipe&…

ptrade排坑日记——一键脚本报错,启动jupyterhub失败。

前言 今天要和大家分享的是在使用ptrade过程中遇见的问题——一键脚本报错,启动jupyterhub失败。 一、问题描述 server_operation.pyc-一键脚本报错,启动jupyterhub失败,jupyterhub.log报错: Traceback(most recent call last)…

Linux异步通知

1.异步通知简介 我们首先来回顾一下“中断”,中断是处理器提供的一种异步机制,我们配置好中断以后就可以让处理器去处理其他的事情了,当中断发生以后会触发我们事先设置好的中断服务函数,在中断服务函数中做具体的处理。 信号类似于我们硬件上使用的“中断”,只不过信号是软件…

在前端开发中使用命令模式:JavaScript和Vue的实现技巧

在前端开发中使用命令模式:JavaScript和Vue的实现技巧 1. 引言 命令模式(Command Pattern)是一种行为设计模式,它将请求的发送者和请求的接收者解耦。该模式允许将请求封装为一个对象,从而可以使用不同的请求、队列请…