疯狂的狮子li
2021-12-03 8b9d3541ddb6271cc8db9b1230fad80a7ecc1dcf
update LoginUser 增加角色缓存 优化角色权限代码
已修改4个文件
62 ■■■■ 文件已修改
ruoyi-admin/src/main/java/com/ruoyi/web/controller/system/SysRoleController.java 2 ●●● 补丁 | 查看 | 原始文档 | blame | 历史
ruoyi-common/src/main/java/com/ruoyi/common/core/domain/model/LoginUser.java 23 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
ruoyi-framework/src/main/java/com/ruoyi/framework/web/service/PermissionService.java 29 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
ruoyi-system/src/main/java/com/ruoyi/system/service/impl/UserDetailsServiceImpl.java 8 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
ruoyi-admin/src/main/java/com/ruoyi/web/controller/system/SysRoleController.java
@@ -108,7 +108,7 @@
            LoginUser loginUser = getLoginUser();
            SysUser sysUser = userService.selectUserById(loginUser.getUserId());
            if (StringUtils.isNotNull(sysUser) && !sysUser.isAdmin()) {
                loginUser.setPermissions(permissionService.getMenuPermission(sysUser));
                loginUser.setMenuPermissions(permissionService.getMenuPermission(sysUser));
                tokenService.setLoginUser(loginUser);
            }
            return AjaxResult.success();
ruoyi-common/src/main/java/com/ruoyi/common/core/domain/model/LoginUser.java
@@ -69,9 +69,14 @@
    private String os;
    /**
     * 权限列表
     * 菜单权限
     */
    private Set<String> permissions;
    private Set<String> menuPermissions;
    /**
     * 角色权限
     */
    private Set<String> rolePermissions;
    /**
     * 用户名
@@ -82,20 +87,6 @@
     * 密码
     */
    private String password;
    public LoginUser(String username, String password, Set<String> permissions) {
        this.username = username;
        this.password = password;
        this.permissions = permissions;
    }
    public LoginUser(Long userId, Long deptId, String username, String password, Set<String> permissions) {
        this.userId = userId;
        this.deptId = deptId;
        this.username = username;
        this.password = password;
        this.permissions = permissions;
    }
    @JsonIgnore
    @Override
ruoyi-framework/src/main/java/com/ruoyi/framework/web/service/PermissionService.java
@@ -1,12 +1,8 @@
package com.ruoyi.framework.web.service;
import com.ruoyi.common.core.domain.entity.SysRole;
import com.ruoyi.common.core.domain.entity.SysUser;
import com.ruoyi.common.core.domain.model.LoginUser;
import com.ruoyi.common.core.service.UserService;
import com.ruoyi.common.utils.SecurityUtils;
import com.ruoyi.common.utils.StringUtils;
import com.ruoyi.common.utils.spring.SpringUtils;
import org.springframework.stereotype.Service;
import org.springframework.util.CollectionUtils;
@@ -44,10 +40,10 @@
            return false;
        }
        LoginUser loginUser = SecurityUtils.getLoginUser();
        if (StringUtils.isNull(loginUser) || CollectionUtils.isEmpty(loginUser.getPermissions())) {
        if (StringUtils.isNull(loginUser) || CollectionUtils.isEmpty(loginUser.getMenuPermissions())) {
            return false;
        }
        return hasPermissions(loginUser.getPermissions(), permission);
        return hasPermissions(loginUser.getMenuPermissions(), permission);
    }
    /**
@@ -71,10 +67,10 @@
            return false;
        }
        LoginUser loginUser = SecurityUtils.getLoginUser();
        if (StringUtils.isNull(loginUser) || CollectionUtils.isEmpty(loginUser.getPermissions())) {
        if (StringUtils.isNull(loginUser) || CollectionUtils.isEmpty(loginUser.getMenuPermissions())) {
            return false;
        }
        Set<String> authorities = loginUser.getPermissions();
        Set<String> authorities = loginUser.getMenuPermissions();
        for (String permission : permissions.split(PERMISSION_DELIMETER)) {
            if (permission != null && hasPermissions(authorities, permission)) {
                return true;
@@ -97,12 +93,11 @@
        if (StringUtils.isNull(loginUser)) {
            return false;
        }
        SysUser sysUser = SpringUtils.getBean(UserService.class).selectUserById(loginUser.getUserId());
        if (CollectionUtils.isEmpty(sysUser.getRoles())) {
        Set<String> rolePermissions = loginUser.getRolePermissions();
        if (CollectionUtils.isEmpty(rolePermissions)) {
            return false;
        }
        for (SysRole sysRole : sysUser.getRoles()) {
            String roleKey = sysRole.getRoleKey();
        for (String roleKey : rolePermissions) {
            if (SUPER_ADMIN.equals(roleKey) || roleKey.equals(StringUtils.trim(role))) {
                return true;
            }
@@ -134,13 +129,15 @@
        if (StringUtils.isNull(loginUser)) {
            return false;
        }
        SysUser sysUser = SpringUtils.getBean(UserService.class).selectUserById(loginUser.getUserId());
        if (CollectionUtils.isEmpty(sysUser.getRoles())) {
        Set<String> rolePermissions = loginUser.getRolePermissions();
        if (CollectionUtils.isEmpty(rolePermissions)) {
            return false;
        }
        for (String role : roles.split(ROLE_DELIMETER)) {
            if (hasRole(role)) {
                return true;
            for (String roleKey : rolePermissions) {
                if (SUPER_ADMIN.equals(roleKey) || roleKey.equals(StringUtils.trim(role))) {
                    return true;
                }
            }
        }
        return false;
ruoyi-system/src/main/java/com/ruoyi/system/service/impl/UserDetailsServiceImpl.java
@@ -47,6 +47,12 @@
    }
    public UserDetails createLoginUser(SysUser user) {
        return new LoginUser(user.getUserId(), user.getDeptId(), user.getUserName(), user.getPassword(), permissionService.getMenuPermission(user));
        return new LoginUser()
            .setUserId(user.getUserId())
            .setDeptId(user.getDeptId())
            .setUsername(user.getUserName())
            .setPassword(user.getPassword())
            .setMenuPermissions(permissionService.getMenuPermission(user))
            .setRolePermissions(permissionService.getRolePermission(user));
    }
}