RBAC-自定义注解实现权限校验

1 自定义权限注解

@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.METHOD)
public @interface NeedPermissions {
    String permission() default "";
}

2 定义拦截器拦截请求

@Component
@Slf4j
public class PermissionInterceptor implements HandlerInterceptor {

    @Autowired
    private IUserService userService;

    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        if (handler instanceof HandlerMethod) {
            HandlerMethod handlerMethod = (HandlerMethod) handler;
            NeedPermissions methodAnnotation = handlerMethod.getMethodAnnotation(NeedPermissions.class);
            if (methodAnnotation == null) {
                return true;
            }
            String permission = methodAnnotation.permission();
            if (StrUtil.isBlank(permission)) {
                return true;
            }
            // 获取当前用户的权限
            List<Menu> menus = userService.selectMenuByUserId(1);
            Set<String> collect = menus.stream().map(Menu::getPerms).collect(Collectors.toSet());
            log.info("请求需要的权限:{}", permission);
            if (collect.contains(permission)) {
                return true;
            }
            setResponseData(response, "权限不足");
            return false;
        }
        return HandlerInterceptor.super.preHandle(request, response, handler);
    }

    private void setResponseData(HttpServletResponse response, String message) throws IOException {
        response.setStatus(HttpServletResponse.SC_UNAUTHORIZED);
        response.setContentType("application/json;charset=UTF-8");
        response.getWriter().write("{\"status\":401,\"message\":\"" + message + "\"}");
    }
}

3 注册拦截器

@Configuration
public class WebConfig implements WebMvcConfigurer {

   @Autowired
   private LoginInterceptor loginInterceptor;
   @Autowired
   private PermissionInterceptor permissionInterceptor;

   @Override
   public void addInterceptors(InterceptorRegistry registry) {
       registry.addInterceptor(loginInterceptor).addPathPatterns("/**")
               .excludePathPatterns("/doc.html", "/v3/api-docs/**");
       registry.addInterceptor(permissionInterceptor).addPathPatterns("/**")
               .excludePathPatterns("/doc.html", "/v3/api-docs/**");
   }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

BananaNo2

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值