Spring Boot整合Security系列步骤及问题排查(十六)—— 动态授权管理

1.新建RbacService:

/**
 * 项目授权服务接口
 *
 * @author zhaohaibin
 */
public interface RbacService {

    /**
     * 权限判断
     *
     * @param request
     * @param authentication
     * @return
     */
    boolean hasPermission(HttpServletRequest request, Authentication authentication);

}

2.实现RbacService:

/**
 * 项目授权服务接口实现
 *
 * @author zhaohaibin
 */
@Component("rbacService")
public class RbacServiceImpl implements RbacService {

    private AntPathMatcher antPathMatcher = new AntPathMatcher();

    @Override
    public boolean hasPermission(HttpServletRequest request, Authentication authentication) {
        Object principal = authentication.getPrincipal();

        boolean hasPermission = false;

        if (principal instanceof UserDetails) {
            // 如果用户名是admin,就永远返回true
            if (StringUtils.equals(((UserDetails) principal).getUsername(), ISysConstants.S_SYSTEM_SUPER_ADMIN)) {
                hasPermission = true;
            } else {
                // 读取用户所拥有权限的所有URL
                Set<String> urls = ((SystemUserDto) principal).getUrls();
                for (String url : urls) {
                    if (antPathMatcher.match(SecurityConstants.DEFAULT_PROJECT_NAME_URL + url, request.getRequestURI())) {
                        hasPermission = true;
                        break;
                    }
                }
            }
        }

        return hasPermission;
    }

}

SystemUserDto extends SystemUserPojo;
SystemUserPojo implements UserDetails

更新loadUserByUsername方法返回对象:

@Override
public SystemUserDto loadUserByUsername(String userName) throws UsernameNotFoundException{...}

3.引用RbacServiceImpl(更新MyAuthorizeConfigProvider):

/**
 * 项目授权配置
 *
 * @author zhaohaibin
 */
@Component
@Order(Integer.MAX_VALUE)
public class MyAuthorizeConfigProvider implements AuthorizeConfigProvider {
    @Override
    public void config(ExpressionUrlAuthorizationConfigurer<HttpSecurity>.ExpressionInterceptUrlRegistry config) {

//        config.antMatchers("/user").hasRole("ADMIN");

        config.anyRequest().access("@rbacService.hasPermission(request,authentication)");

    }
}

4.因为都要执行config.anyRequest(),所以增加Order注解,同时更新DemoAuthorizeConfigManager和DemoAuthorizeConfigProvider:
DemoAuthorizeConfigManager:

        // 其余请求都要认证
//        config.anyRequest().authenticated();

DemoAuthorizeConfigProvider:

@Component
@Order(Integer.MIN_VALUE)
public class DemoAuthorizeConfigProvider implements AuthorizeConfigProvider {...}

问题排查:
暂无

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值