spring-security通过数据库动态配置权限

@Component
public class CustomAuthorizationManager implements AuthorizationManager<RequestAuthorizationContext> {

    private static final AuthorizationDecision DENY = new AuthorizationDecision(false);

    private final List<RequestMatcherEntry<AuthorizationManager<RequestAuthorizationContext>>> mappings;


    @Autowired
    private HandlerMappingIntrospector introspector;

    public CustomAuthorizationManager(@Autowired MenuMapper menuRepository) {
        MvcRequestMatcher.Builder mvcMatcherBuilder = new MvcRequestMatcher.Builder(introspector);
        mappings = new ArrayList<>();
        //AndRequestMatcher
        AuthorizationManager<RequestAuthorizationContext> requestAuthorizationContextAuthorizationManager = (context, variables) -> new AuthorizationDecision(true);
        List<Menu> allMenus = menuRepository.findAll();
        for (Menu menu : allMenus) {
            List<Role> roles = menu.getRoles();
            String[] roleArr = new String[roles.size()];
            for (int i = 0; i < roleArr.length; i++) {
                roleArr[i] = roles.get(i).getName();
            }
            RequestMatcher pattern = mvcMatcherBuilder.pattern(menu.getPattern());
            if (roleArr.length == 0) {
                mappings.add(new RequestMatcherEntry(pattern, requestAuthorizationContextAuthorizationManager));
            }else{
                mappings.add(new RequestMatcherEntry(pattern, AuthorityAuthorizationManager.hasAnyAuthority(roleArr)));
            }
        }
        mappings.add(new RequestMatcherEntry(AnyRequestMatcher.INSTANCE, new AuthenticatedAuthorizationManager()));//其他登录才能访问
    }

    @Override
    public AuthorizationDecision check(Supplier<Authentication> authentication, RequestAuthorizationContext request) {
        Iterator var3 = this.mappings.iterator();

        RequestMatcherEntry mapping;
        RequestMatcher.MatchResult matchResult;
        do {
            if (!var3.hasNext()) {
                return DENY;
            }

            mapping = (RequestMatcherEntry) var3.next();
            RequestMatcher matcher = mapping.getRequestMatcher();
            matchResult = matcher.matcher(request.getRequest());
        } while (!matchResult.isMatch());

        AuthorizationManager<RequestAuthorizationContext> manager = (AuthorizationManager) mapping.getEntry();

        return manager.check(authentication, request);

    }
}
   @Bean
    public SecurityFilterChain filterChain(HttpSecurity http) throws Exception {
        http.csrf(csrf -> csrf.disable())
                .userDetailsService(userDetailsService)
                .httpBasic(withDefaults())
                .authorizeHttpRequests((authorize) -> {
                            authorize
                                    .anyRequest().access(authorizationManager);
                        }
                )
                .logout(logout -> logout
                        .logoutSuccessHandler(logoutSuccessHandler)//登录成功
                        .invalidateHttpSession(true)
                )
                .formLogin(formLogin -> formLogin
                        .successHandler(authenticationSuccessHandler)//登录成功
                        .failureHandler(authenticationFailureHandler)//登录失败
                )
        ;
        return http.build();
    }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值