若依vue(前后端分离版本)前端获取登录用户id

本文详细介绍了在RuoYi框架中,如何在user.js的state和mutations中添加用户ID属性,并在GetInfo方法中设置缓存。同时,展示了如何在前端页面中通过store获取和使用缓存的用户ID。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

步骤流程

1.找到user.js

2.在user.js中找到以下几个地方

  • 属性:state{}
  • 属性:mutations{}
  • 函数:GetInfo()

3.在user.js中添加代码 

4.在自己的页面中添加获取id的代码

步骤一

在该若依的版本中,从下列目录找到,ruoyi-ui->src->store->modules->user.js

 步骤二

属性state在页面中的位置

state: {
    token: getToken(),
    name: '',
    avatar: '',
    roles: [],
    permissions: []
  },

还有mutations

mutations: {
    SET_TOKEN: (state, token) => {
      state.token = token
    },
    SET_NAME: (state, name) => {
      state.name = name
    },
    SET_AVATAR: (state, avatar) => {
      state.avatar = avatar
    },
    SET_ROLES: (state, roles) => {
      state.roles = roles
    },
    SET_PERMISSIONS: (state, permissions) => {
      state.permissions = permissions
    }
}

最后是GetInfo方法

GetInfo({ commit, state }) {
      return new Promise((resolve, reject) => {
        getInfo().then(res => {
          const user = res.user
          const avatar = (user.avatar == "" || user.avatar == null) ?                     require("@/assets/images/profile.jpg") : process.env.VUE_APP_BASE_API + user.avatar;
          if (res.roles && res.roles.length > 0) { // 验证返回的roles是否是一个非空数组
            commit('SET_ROLES', res.roles)
            commit('SET_PERMISSIONS', res.permissions)
          } else {
            commit('SET_ROLES', ['ROLE_DEFAULT'])
          }
          commit('SET_NAME', user.userName)
          commit('SET_AVATAR', avatar)
          resolve(res)
        }).catch(error => {
          reject(error)
        })
      })
    },

步骤三

到此处开始添加代码

user.js中,state

添加id属性

state: {
    token: getToken(),
    name: '',
    id:'',//添加的用户id
    avatar: '',
    roles: [],
    permissions: []
  },
mutations中添加SET_ID
mutations: {
//添加方法
    SET_ID: (state, userId) => {
      state.id = userId
    },
    SET_TOKEN: (state, token) => {
      state.token = token
    },
    SET_NAME: (state, name) => {
      state.name = name
    },
    SET_AVATAR: (state, avatar) => {
      state.avatar = avatar
    },
    SET_ROLES: (state, roles) => {
      state.roles = roles
    },
    SET_PERMISSIONS: (state, permissions) => {
      state.permissions = permissions
    }

最后在GetInfo中添加,设置缓存id的代码

commit('SET_ID', user.userId)

// 获取用户信息
    GetInfo({ commit, state }) {
      return new Promise((resolve, reject) => {
        getInfo().then(res => {
          const user = res.user
          const avatar = (user.avatar == "" || user.avatar == null) ? require("@/assets/images/profile.jpg") : process.env.VUE_APP_BASE_API + user.avatar;
          if (res.roles && res.roles.length > 0) { // 验证返回的roles是否是一个非空数组
            commit('SET_ROLES', res.roles)
            commit('SET_PERMISSIONS', res.permissions)
          } else {
            commit('SET_ROLES', ['ROLE_DEFAULT'])
          }
          commit('SET_ID', user.userId)//添加这行代码
          commit('SET_NAME', user.userName)
          commit('SET_AVATAR', avatar)
          resolve(res)
        }).catch(error => {
          reject(error)
        })
      })
    },

步骤三

在自己的页面中使用缓存中的用户id

首先导入包import store from "@/store";写在<script>标签中

<script>
import store from "@/store";
export default {
    data(){
     return{
         userId:store.state.user.id//将缓存的用户id赋值给userId
     }
    }
}
。。。。。
</script>

参考文章:如何前台页面获取用户ID信息? · Issue #I3OVTU · 若依/RuoYi - Gitee.com

<think>好的,我现在需要帮助用户解决在若依框架前后端分离版中,前端如何获取用户自己ID的问题。首先,我要回顾一下之前的对话历史,确保理解用户的需求和之前的上下文。 用户之前询问了后端如何实现微信协议的重定向,现在转向前端如何获取用户ID,这可能是因为他们正在开发一个需要用户身份识别的功能,比如个人资料页面或权限控制。我需要确保回答准确且符合若依框架的结构。 首先,若依框架的前后端分离版通常使用Vue作为前端,Spring Boot作为后端,权限管理可能使用Spring Security或Shiro。用户登录后,后端会生成一个token,前端存储这个token,并在每次请求时携带它。用户ID可能存储在token中,或者通过API接口获取。 接下来,我需要考虑前端获取用户ID的几种常见方式。通常,用户登录成功后,后端会返回用户信息,包括用户ID前端可以将这些信息存储在Vuex或本地存储中。此外,每次请求用户信息时,前端可能需要调用特定的API,比如/getInfo,来获取详细信息。 需要注意的是,若依框架可能有自己的实现方式,比如在登录成功后,调用某个接口获取用户信息,并将用户ID存储在Vuex的state中。此外,路由守卫可能会在页面跳转时自动获取用户信息,确保用户已认证。 用户可能遇到的问题包括:用户ID未正确存储、token失效或权限问题,以及多标签页同步问题。因此,在回答中需要提供解决方案,比如检查登录流程、使用Vuex持久化插件、处理token过期,以及调用用户信息接口主动更新数据。 另外,需要确保回答结构清晰,步骤明确,帮助用户逐步解决问题。可能还需要提到调试方法,比如查看Vuex状态、检查网络请求,以及后端接口的安全性,比如用户ID不应明文传输。 总结来说,前端获取用户ID的主要步骤包括:登录后存储用户信息、通过Vuex或本地存储访问、使用路由守卫自动获取,以及调用用户信息接口。同时,需要处理常见问题和提供调试建议,确保用户能够顺利实现功能。</think>若依框架(RuoYi-Vue前后端分离版中,前端获取当前用户ID的实现方式如下: --- ### 一、核心实现原理 1. **登录态保持**:用户登录后后端返回`access_token` 2. **用户信息存储**:前端用户信息缓存在`Vuex`状态管理库 3. **请求头自动注入**:通过axios拦截器自动携带`Authorization`头 --- ### 二、具体实现步骤 #### 步骤1:登录获取用户信息 ```javascript // 登录成功回调(通常位于 src/api/login.js) this.$store.dispatch('Login', this.loginForm).then(() => { // 自动触发用户信息获取 this.$store.dispatch('GetInfo').then(userInfo => { console.log('当前用户ID:', userInfo.userId) // 用户ID存储在userInfo中 }) }) ``` #### 步骤2:直接访问Vuex存储(推荐) ```javascript // 在任何Vue组件中 computed: { userId() { return this.$store.state.user.userId } }, mounted() { console.log('当前用户ID:', this.userId) } ``` #### 步骤3:通过Cookie/LocalStorage获取(备选方案) ```javascript // 查看存储的token信息(需配合JWT解析) import { getToken } from '@/utils/auth' const token = getToken() // 若依默认不直接暴露用户ID,需解析JWT(需后端配合) const payload = JSON.parse(atob(token.split('.')[1])) console.log('JWT中的用户ID:', payload.userid) ``` --- ### 三、关键代码位置 | 文件路径 | 作用 | |---------|------| | `src/store/modules/user.js` | 用户信息存储核心逻辑 | | `src/permission.js` | 路由守卫自动获取用户信息 | | `src/utils/request.js` | axios拦截器处理身份凭证 | --- ### 四、注意事项 1. **安全规范**: ```javascript // 禁止在前端暴露敏感字段(用户ID应通过加密传输) process.env.VUE_APP_USER_ID_FIELD = 'safeUserId' // 在.env文件中配置字段名 ``` 2. **多标签页同步**: ```javascript // 监听storage事件保持数据同步 window.addEventListener('storage', event => { if (event.key === 'vuex') { this.$store.replaceState(JSON.parse(event.newValue)) } }) ``` 3. **调试技巧**: ```javascript // 在浏览器控制台快速查看(需开发环境) localStorage.getItem('vuex') // 查看完整存储状态 ``` --- ### 五、常见问题解决方案 **问题1:用户ID显示为`undefined`** ```javascript // 解决方案:确保已触发GetInfo Action this.$store.dispatch('GetInfo').then(() => { console.log('重新获取用户ID:', this.$store.state.user.userId) }) ``` **问题2:多系统集成时的ID冲突** ```javascript // 在src/settings.js中配置用户ID字段映射 export default { userIdentifierField: 'unionId' // 根据实际接口字段修改 } ``` --- ### 六、最佳实践建议 1. **敏感操作验证**: ```javascript // 关键操作前强制刷新用户信息 async beforeDelete() { await this.$store.dispatch('RefreshUserInfo') if (!this.$store.state.user.userId) { this.$modal.msgError("身份凭证已过期") } } ``` 2. **TypeScript支持**(若使用TS): ```typescript // src/types/user.d.ts declare interface UserState { userId: number | string // 其他用户字段... } ``` --- ### 附:用户信息流向示意图 ``` [登录接口] → 返回token → [GetInfo接口] → 用户ID存入Vuex → 全局状态共享 ↗ 自动注入token ↘ [其他API请求] [页面组件访问] ``` 实际开发中建议始终通过`this.$store.state.user.userId`获取,避免直接操作本地存储,确保数据一致性。
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值