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

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

步骤流程

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

  • 6
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue前后端分离的开发模式下,如何处理Session问题是一个常见的需求。由于前后端分离的特点,前端与后端之间的通信是通过API接口进行的,因此在处理Session时需要考虑如何保持用户登录状态。 一种常见的方式是使用Token来管理Session。当用户成功登录后,后端会生成一个Token,并将其返回给前端前端在后续的请求中需要将该Token携带在请求的Header中,以便后端进行鉴权。后端在接收到请求时,会验证Token的有效性,如果验证通过,则继续处理请求,否则返回错误信息。 在前端中,可以使用localStorage或者cookie来保存Token。当用户访问页面时,前端可以先尝试从localStorage或cookie中获取Token,并将其添加到请求的Header中,以保证用户登录状态。当用户退出登录时,前端需要删除保存的Token,以确保下次访问时用户需要重新登录。 当然,为了增强安全性,可以在Token中加入一些额外的信息,如过期时间、权限等,以确保用户的身份和授权信息的有效性。 此外,还可以使用JWT(JSON Web Token)来管理Session。JWT是一种基于JSON的开放标准,可以用于在某些信任的环境中安全地传输信息。JWT由头部、载荷和签名三部分组成,其中载荷部分可以储存用户的数据,例如用户ID用户名等。通过对头部和载荷进行签名,可以保证JWT的完整性和可信度。 总而言之,Vue前后端分离的Session管理可以通过Token或JWT来实现。这样可以实现用户登录状态的保持,并且提供一定的安全性保障。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值