SpringBoot拦截器的简单使用

SpringBoot拦截器的使用

在这里插入图片描述

核心文件

PrivilageInterceptor

配置
package cn.bjwlxy.interceptor;


import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import cn.bjwlxy.model.UserModel;
import org.springframework.stereotype.Controller;
import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView;




@Controller
public class PrivilageInterceptor implements HandlerInterceptor{

	@Override
	public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) {
//        System.out.println("执行了TestInterceptor的preHandle方法");
		try {
			//统一拦截(查询当前session是否存在user)(这里user会在每次登陆成功后,写入session)
			UserModel user=(UserModel)request.getSession().getAttribute("user");
			if(user!=null){
				return true;
			}
			request.setAttribute("msg","您尚未登录,请登录!");

			request.getRequestDispatcher(request.getContextPath()+"/login.jsp").forward(request,response);
		} catch (Exception e) {
			e.printStackTrace();
		}
		return false;//如果设置为false时,被请求时,拦截器执行到此处将不会继续操作
		//如果设置为true时,请求将会继续执行后面的操作
	}

	/**
	 * 请求处理之后进行调用,但是在视图被渲染之前(Controller方法调用之后)
	 */
	@Override
	public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) {
//         System.out.println("执行了TestInterceptor的postHandle方法");
	}

	/**
	 * 在整个请求结束之后被调用,也就是在DispatcherServlet 渲染了对应的视图之后执行(主要是用于进行资源清理工作)
	 */
	@Override
	public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) {
//        System.out.println("执行了TestInterceptor的afterCompletion方法");
	}
}

配置 LoginConfig

package cn.bjwlxy.config;


import cn.bjwlxy.interceptor.PrivilageInterceptor;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.InterceptorRegistration;
import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;


@Configuration
public class LoginConfig implements WebMvcConfigurer {

    @Override
    public void addInterceptors(InterceptorRegistry registry) {
        //注册TestInterceptor拦截器
        InterceptorRegistration registration = registry.addInterceptor(new PrivilageInterceptor());
        registration.addPathPatterns("/**");                      //所有路径都被拦截
        registration.excludePathPatterns(                         //添加不拦截路径
                "你的登陆路径",            //登录
                "/**/*.js",              //js静态资源
                "/**/*.css",             //css静态资源
                "/**/*.xml",
                "/login.jsp",
                "/user/login"
        );
    }
}
Spring Boot 中的拦截器可以通过实现 `HandlerInterceptor` 接口来创建,并通过 `WebMvcConfigurer` 配置进行注册。 下面是一个简单的示例: 1. 创建一个实现 `HandlerInterceptor` 接口的拦截器类: ```java public class MyInterceptor implements HandlerInterceptor { @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { // 在请求处理之前进行拦截,可以进行权限校验等操作 return true; // 返回 true 表示继续执行后续的请求处理,返回 false 则表示拦截该请求 } @Override public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception { // 在请求处理之后、视图渲染之前进行拦截,可以添加一些通用的数据到模型中 } @Override public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception { // 在整个请求完成之后进行拦截,可以进行一些资源清理等操作 } } ``` 2. 创建一个配置类并注册拦截器: ```java @Configuration public class WebMvcConfig implements WebMvcConfigurer { @Override public void addInterceptors(InterceptorRegistry registry) { registry.addInterceptor(new MyInterceptor()) .addPathPatterns("/**") // 添加拦截路径规则 .excludePathPatterns("/login"); // 排除不需要拦截的路径 } } ``` 在上面的示例中,使用 `addInterceptor` 方法将自定义的拦截器注册到拦截器链中,并使用 `addPathPatterns` 方法添加需要拦截的路径规则,使用 `excludePathPatterns` 方法排除不需要拦截的路径。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值