From 8819e79adb6a87de0cc3c8bee684e7b07fa7ea7d Mon Sep 17 00:00:00 2001 From: Administrator <zhubaomin> Date: 星期一, 15 一月 2024 22:11:19 +0800 Subject: [PATCH] 2024-01-15 朱宝民 优化获取用户信息接口 --- pipIrr-platform/pipIrr-web/pipIrr-web-base/src/main/java/com/dy/pipIrrBase/user/UserSv.java | 48 +++++++++++++++++++++++++++++++++++++++++++----- 1 files changed, 43 insertions(+), 5 deletions(-) diff --git a/pipIrr-platform/pipIrr-web/pipIrr-web-base/src/main/java/com/dy/pipIrrBase/user/UserSv.java b/pipIrr-platform/pipIrr-web/pipIrr-web-base/src/main/java/com/dy/pipIrrBase/user/UserSv.java index ebe2415..8e5fbc6 100644 --- a/pipIrr-platform/pipIrr-web/pipIrr-web-base/src/main/java/com/dy/pipIrrBase/user/UserSv.java +++ b/pipIrr-platform/pipIrr-web/pipIrr-web-base/src/main/java/com/dy/pipIrrBase/user/UserSv.java @@ -1,9 +1,14 @@ package com.dy.pipIrrBase.user; +import com.alibaba.fastjson2.JSON; +import com.alibaba.fastjson2.JSONArray; +import com.alibaba.fastjson2.JSONObject; import com.dy.common.webUtil.QueryResultVo; +import com.dy.pipIrrGlobal.daoBa.BaRolePermissionsMapper; import com.dy.pipIrrGlobal.daoBa.BaUserMapper; import com.dy.pipIrrGlobal.daoBa.BaUserRoleMapper; +import com.dy.pipIrrGlobal.pojoBa.BaRolePermissions; import com.dy.pipIrrGlobal.pojoBa.BaUser; import com.dy.pipIrrGlobal.pojoBa.BaUserRole; import com.dy.pipIrrGlobal.voBa.VoUserInfo; @@ -13,9 +18,7 @@ import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; -import java.util.List; -import java.util.Map; -import java.util.Random; +import java.util.*; @Slf4j @Service @@ -23,6 +26,7 @@ private BaUserMapper dao; private BaUserRoleMapper urDao; + private BaRolePermissionsMapper baRolePermissionsMapper; @Autowired private void setDao(BaUserMapper dao) { @@ -32,6 +36,11 @@ @Autowired private void setDao(BaUserRoleMapper dao) { this.urDao = dao; + } + + @Autowired + private void setDao(BaRolePermissionsMapper dao) { + this.baRolePermissionsMapper = dao; } /** @@ -168,7 +177,36 @@ * @param userId 鐢ㄦ埛缂栧彿 * @return 鐢ㄦ埛淇℃伅鍒楄〃 */ - public List<VoUserInfo> getUserInfos(Long userId) { - return dao.getUserInfos(userId); + public VoUserInfo getUserInfos(Long userId) { + VoUserInfo voUserInfo = new VoUserInfo(); + JSONArray array_permission = new JSONArray(); + Map map = Optional.ofNullable(dao.getUserInfoById(userId)).orElse(new HashMap()); + if(map.size() > 0) { + voUserInfo.setUserId(String.valueOf(userId)); + voUserInfo.setUserName(map.get("userName").toString()); + } + + List list_roleIds = new ArrayList(); + List list_roleNames = new ArrayList(); + + List<Map<String, Object>> list = Optional.ofNullable(urDao.getPermissionsByUserId(userId)).orElse(new ArrayList<>()); + if(list.size() > 0) { + JSONArray array= JSONArray.parseArray(JSON.toJSONString(list)); + for (int i = 0; i < array.size(); i++) { + JSONObject job = array.getJSONObject(i); + list_roleIds.add(job.getLong("roleId").toString()); + list_roleNames.add(job.getString("roleName")); + + Long perId = Optional.ofNullable(job.getLong("perId")).orElse(0L); + BaRolePermissions baRolePermissions = baRolePermissionsMapper.selectByPrimaryKey(perId); + if(baRolePermissions != null) { + array_permission.addAll(baRolePermissions.getPermissions()); + } + } + voUserInfo.setRoleIds(list_roleIds); + voUserInfo.setRoleNames(list_roleNames); + voUserInfo.setPermissions(array_permission); + } + return voUserInfo; } } -- Gitblit v1.8.0