当前位置:   article > 正文

若依vue(前后端分离版本)前端获取登录用户id_若依前端获取当前登录用户信息

若依前端获取当前登录用户信息

步骤流程

1.找到user.js

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

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

3.在user.js中添加代码 

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

步骤一

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

 步骤二

属性state在页面中的位置

  1. state: {
  2. token: getToken(),
  3. name: '',
  4. avatar: '',
  5. roles: [],
  6. permissions: []
  7. },

还有mutations

  1. mutations: {
  2. SET_TOKEN: (state, token) => {
  3. state.token = token
  4. },
  5. SET_NAME: (state, name) => {
  6. state.name = name
  7. },
  8. SET_AVATAR: (state, avatar) => {
  9. state.avatar = avatar
  10. },
  11. SET_ROLES: (state, roles) => {
  12. state.roles = roles
  13. },
  14. SET_PERMISSIONS: (state, permissions) => {
  15. state.permissions = permissions
  16. }
  17. }

最后是GetInfo方法

  1. GetInfo({ commit, state }) {
  2. return new Promise((resolve, reject) => {
  3. getInfo().then(res => {
  4. const user = res.user
  5. const avatar = (user.avatar == "" || user.avatar == null) ? require("@/assets/images/profile.jpg") : process.env.VUE_APP_BASE_API + user.avatar;
  6. if (res.roles && res.roles.length > 0) { // 验证返回的roles是否是一个非空数组
  7. commit('SET_ROLES', res.roles)
  8. commit('SET_PERMISSIONS', res.permissions)
  9. } else {
  10. commit('SET_ROLES', ['ROLE_DEFAULT'])
  11. }
  12. commit('SET_NAME', user.userName)
  13. commit('SET_AVATAR', avatar)
  14. resolve(res)
  15. }).catch(error => {
  16. reject(error)
  17. })
  18. })
  19. },

步骤三

到此处开始添加代码

user.js中,state

添加id属性

  1. state: {
  2. token: getToken(),
  3. name: '',
  4. id:'',//添加的用户id
  5. avatar: '',
  6. roles: [],
  7. permissions: []
  8. },
mutations中添加SET_ID
  1. mutations: {
  2. //添加方法
  3. SET_ID: (state, userId) => {
  4. state.id = userId
  5. },
  6. SET_TOKEN: (state, token) => {
  7. state.token = token
  8. },
  9. SET_NAME: (state, name) => {
  10. state.name = name
  11. },
  12. SET_AVATAR: (state, avatar) => {
  13. state.avatar = avatar
  14. },
  15. SET_ROLES: (state, roles) => {
  16. state.roles = roles
  17. },
  18. SET_PERMISSIONS: (state, permissions) => {
  19. state.permissions = permissions
  20. }

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

commit('SET_ID', user.userId)

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

步骤三

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

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

  1. <script>
  2. import store from "@/store";
  3. export default {
  4. data(){
  5. return{
  6. userId:store.state.user.id//将缓存的用户id赋值给userId
  7. }
  8. }
  9. }
  10. 。。。。。
  11. </script>

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

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/神奇cpp/article/detail/852194
推荐阅读
相关标签
  

闽ICP备14008679号