Springboot使用拦截器---之小而美

Springboot使用拦截器

  • 1.创建一个 SpringBoot 框架 Web 项目
  • 2.实现一个登录拦截器
  • 3.创建一个控制层
  • 4.@Configuration 定义配置类-拦截器
  • 5.测试

代码展示

  • 1.创建一个 SpringBoot 框架 Web 项目
  • 2.实现一个登录拦截器
//实现HandlerInterceptor接口,重写preHandle方法
public class UserInterceptor implements HandlerInterceptor {

    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {

        System.out.println("进入拦截器------------------------------");
        //编写业务拦截的规则
        //从session中获取用户的信息
        User user = (User) request.getSession().getAttribute("user");
        //判断用户是否登录
        if (null == user) {
            //未登录
            response.sendRedirect(request.getContextPath() + "/user/error");
            return false;
        }
        return true;
    }
}
  • 3.创建一个控制层,实体层
    实体层User .java
public class User {

    private Integer id;

    private String username;

    public Integer getId() {
        return id;
    }

    public void setId(Integer id) {
        this.id = id;
    }

    public String getUsername() {
        return username;
    }

    public void setUsername(String username) {
        this.username = username;
    }
}

创建控制层UserController .java

@Controller
@RequestMapping(value = "/user")
public class UserController {

    //用户登录的请求,需要排除
    @RequestMapping(value = "/login")
    public @ResponseBody Object login(HttpServletRequest request) {
        //将用户的信息存放到session中
        User user = new User();
        user.setId(1001);
        user.setUsername("zhangsan");
        request.getSession().setAttribute("user",user);

        return "login SUCCESS";
    }

    //该请求需要用户登录之后才可访问
    @RequestMapping(value = "/center")
    public @ResponseBody Object center() {
        return "See Center Message";
    }

    //该请求不登录也可访问
    @RequestMapping(value = "/out")
    public @ResponseBody Object out() {
        return "Out see anytime";
    }

    //如果用户未登录访问了需要登录才可访问的请求,之后会跳转至该请求路径
    //该请求路径不需要用户登录也可访问
    @RequestMapping(value = "/error")
    public @ResponseBody Object error() {
        return "error";
    }
}
  • 4.@Configuration 定义配置类-拦截器
@Configuration  //定义此类为配置文件(即相当于之前的xml配置文件)
public class InterceptorConfig implements WebMvcConfigurer {

    //mvc:interceptors
    @Override
    public void addInterceptors(InterceptorRegistry registry) {

        //要拦截user下的所有访问请求,必须用户登录后才可访问,
        // 但是这样拦截的路径中有一些是不需要用户登录也可访问的
        String[] addPathPatterns = {
            "/user/**"
        };

        //要排除的路径,排除的路径说明不需要用户登录也可访问
        String[] excludePathPatterns = {
            "/user/out", "/user/error","/user/login"
        };

        //mvc:interceptor bean class=""
        registry.addInterceptor(new UserInterceptor()).addPathPatterns(addPathPatterns).excludePathPatterns(excludePathPatterns);
    }
}
  • 5.测试
    启动springboot程序
    访问http://localhost:8080/user/center,
    被拦截器拦截跳转到
    在这里插入图片描述
    访问http://localhost:8080/user/out
    不被拦截,不登录也能访问到该页面
    在这里插入图片描述
    访问http://localhost:8080/user/login
    在这里插入图片描述
    访问http://localhost:8080/user/center
    在这里插入图片描述
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring Boot使用过滤器可以通过以下步骤实现: 1. 在自启动类中添加注解`@ServletComponentScan("com.congge.filter")`,这样Spring Boot会自动扫描并注册过滤器。 2. 创建一个过滤器类,实现`javax.servlet.Filter`接口,并重写`doFilter`方法来实现过滤逻辑。 3. 在过滤器类上添加`@WebFilter`注解,指定过滤器的URL模式和顺序等配置。 4. 运行Spring Boot应用程序,过滤器将会在请求到达时被调用。 关于User-Agent,它是HTTP请求头的一部分,用于标识客户端的软件、操作系统、版本等信息。在过滤器中,你可以通过`HttpServletRequest`对象的`getHeader`方法获取User-Agent的值,然后进行相应的处理。 总结起来,Spring Boot中的过滤器使用方式类似于Spring MVC中的拦截器,但是过滤器的适用范围更广,可以在Servlet容器中使用。过滤器可以深入到请求的前后,而拦截器只能在方法的前后起作用。因此,在Spring框架中,应该优先使用拦截器。\[1\]\[2\]\[3\] #### 引用[.reference_title] - *1* *2* *3* [springboot拦截器与过滤器详解](https://blog.csdn.net/zhangcongyi420/article/details/111455137)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值