拦截器通过自定义注解来判断是否拦截

自定义注解与拦截器实现权限控制
本文介绍了如何通过自定义注解和拦截器实现Spring MVC中的权限控制。首先定义了一个名为`AuthAccess`的注解,标记在需要免拦截的方法上。然后创建了一个拦截器`MyInterceptor`,在预处理方法中检查请求的处理器是否包含该注解,如果存在则放行,否则进行拦截。最后在配置类`WebConfig`中注册了拦截器,并设置拦截路径及排除路径。这种方法允许灵活地控制特定方法的访问权限。

拦截器通过自定义注解来判断是否拦截

自定义一个注解,又有拦截器,方法上只要有这个注解,就不进行拦截,放行

1.自定义注解

import java.lang.annotation.*;

@Target(ElementType.METHOD)
@Retention(RetentionPolicy.RUNTIME)
@Documented
public @interface AuthAccess {
}

2.拦截器配置

public class MyInterceptor implements HandlerInterceptor {
    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        /*...*/
        if(!(handler instanceof HandlerMethod)){
            return true;
        }else {
            HandlerMethod h = (HandlerMethod) handler;
            AuthAccess authAccess = h.getMethodAnnotation(AuthAccess.class);
            if(authAccess!=null){
                return true;
            }
        }
       /*...*/
    }
}

3.配置

@Configuration
public class WebConfig implements WebMvcConfigurer{
    @Override
    public void addInterceptors(InterceptorRegistry registry) {

        registry.addInterceptor(new MyInterceptor())
                .addPathPatterns("/index/**")    
            	.excludePathPatterns("/admin","/admin/login");
    }
}

4.controller层使用

@RestController
public class IndexController {
    @AuthAccess
    @GetMapping("/index")
    public Result index(){
        return Result.success("index");
    }
}

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值