当前位置:首页 » 《资源分享》 » 正文

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

3 人参与  2024年04月11日 17:35  分类 : 《资源分享》  评论

点击全文阅读


步骤流程

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


点击全文阅读


本文链接:http://zhangshiyu.com/post/93951.html

<< 上一篇 下一篇 >>

  • 评论(0)
  • 赞助本站

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。

关于我们 | 我要投稿 | 免责申明

Copyright © 2020-2022 ZhangShiYu.com Rights Reserved.豫ICP备2022013469号-1