Administrator
2024-01-15 48d64c07ea643e1b1199828f6ac36c12c05cd535
2024-01-15 朱宝民 优化获取用户信息接口
3个文件已修改
31 ■■■■■ 已修改文件
pipIrr-platform/pipIrr-global/src/main/java/com/dy/pipIrrGlobal/voBa/VoUserInfo.java 4 ●●● 补丁 | 查看 | 原始文档 | blame | 历史
pipIrr-platform/pipIrr-global/src/main/resources/mapper/BaUserRoleMapper.xml 3 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
pipIrr-platform/pipIrr-web/pipIrr-web-base/src/main/java/com/dy/pipIrrBase/user/UserSv.java 24 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
pipIrr-platform/pipIrr-global/src/main/java/com/dy/pipIrrGlobal/voBa/VoUserInfo.java
@@ -1,5 +1,6 @@
package com.dy.pipIrrGlobal.voBa;
import com.alibaba.fastjson2.JSONArray;
import com.dy.common.po.BaseEntity;
import io.swagger.v3.oas.annotations.media.Schema;
import lombok.Data;
@@ -32,6 +33,7 @@
    private List<Map<String, Object>> roleNames;
    @Schema(title = "权限列表")
    private List<Map<String, Object>> permissions;
    //private List<Map<String, Object>> permissions;
    private JSONArray permissions;
}
pipIrr-platform/pipIrr-global/src/main/resources/mapper/BaUserRoleMapper.xml
@@ -65,7 +65,8 @@
    SELECT
      rol.id AS roleId,
      rol.`name` AS roleName,
      per.permissions
<!--      per.permissions-->
      per.id AS perId
    FROM ba_user_role use_rol
           INNER JOIN ba_role rol ON rol.id = use_rol.roleId
           INNER JOIN ba_role_permissions per ON per.roleId = rol.id
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,7 +179,7 @@
     */
    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);
@@ -180,7 +188,6 @@
        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) {
@@ -190,18 +197,15 @@
                list_roleIds.add(job.getLong("roleId"));
                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;
    }