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 | 28 ++++++++++++++++------------ 1 files changed, 16 insertions(+), 12 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 1a41c18..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 @@ -5,8 +5,10 @@ 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; @@ -24,6 +26,7 @@ private BaUserMapper dao; private BaUserRoleMapper urDao; + private BaRolePermissionsMapper baRolePermissionsMapper; @Autowired private void setDao(BaUserMapper dao) { @@ -33,6 +36,11 @@ @Autowired private void setDao(BaUserRoleMapper dao) { this.urDao = dao; + } + + @Autowired + private void setDao(BaRolePermissionsMapper dao) { + this.baRolePermissionsMapper = dao; } /** @@ -171,37 +179,33 @@ */ public VoUserInfo getUserInfos(Long userId) { VoUserInfo voUserInfo = new VoUserInfo(); - String permission = ""; + JSONArray array_permission = new JSONArray(); Map map = Optional.ofNullable(dao.getUserInfoById(userId)).orElse(new HashMap()); if(map.size() > 0) { - voUserInfo.setUserId(userId); + voUserInfo.setUserId(String.valueOf(userId)); voUserInfo.setUserName(map.get("userName").toString()); } List list_roleIds = new ArrayList(); List list_roleNames = new ArrayList(); - List list_permissions = 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")); + list_roleIds.add(job.getLong("roleId").toString()); list_roleNames.add(job.getString("roleName")); - String permissions = Optional.ofNullable(job.getString("permissions")).orElse(""); - if(permissions.length() > 0) { - permissions = permissions.substring(1, permissions.length() - 1); - permissions= permissions.replace(String.valueOf(" "), ""); - permission = permission + permissions + ","; + 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); - permission = permission.substring(0, permission.length()-1); - list_permissions.add(permission); - voUserInfo.setPermissions(list_permissions); + voUserInfo.setPermissions(array_permission); } return voUserInfo; } -- Gitblit v1.8.0