Spring框架的拦截器(Interceptor)

        SpringMVC的拦截器 与 JavaServlet的过滤器 类似,它主要用于拦截用户的请求并做相应的处理,通常应用于权限认证(保护服务器资源 )、记录请求信息的日志、判断用户是否登录等功能。

自定义登录拦截器

 一、创建一个类并实现HandlerInterceptor接口,这个接口包含了三个方法:preHandle、postHandle和afterCompletion。

boolean preHandle() 方法:

  • 在请求到达目标资源或controller之前执行。当该方法返回值为true时,则允许请求到达目标资源或下一拦截器。当方法返回值为false时,则阻止请求继续访问。

void postHandle()方法:

  • 该方法在请求到达目标资源或controller执行完成以后执行,前提是, boolean preHandle() 方法返回值为true。

void afterCompletion方法:

  • 该方法在服务器渲染页面以后执行,前提是 boolean preHandle() 方法返回值为true。

//util类
@Component
public class LoginInterceptor implements HandlerInterceptor {
    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        //从session中 取出 登录用户
        Object user = request.getSession().getAttribute("loginUser");
        if(user!=null){
            return true;
        }
        /**重定向到 登录页面 */
        response.sendRedirect("/login.html?info=noland");
        return false;
    }
}

 二、注册拦截器类,重写addInterceptors方法

//config类
@Configuration
public class WebConfig implements WebMvcConfigurer {
    @Override
    public void addInterceptors(InterceptorRegistry registry) {
//注册自定义拦截器
       registry.addInterceptor(new LoginInterceptor())
//路径匹配 受限资源拦截范围  访问该范围资源就会被拦截(可以写多个)
               .addPathPatterns("/index.html");
    }
}

三、在登录页面显示拦截信息

window.onload = function () {
    let info = getQuery("info");
    if(info=="noland"){
        $("infoDiv").innerHTML = "请先登录";
    }
}

猜你喜欢

转载自blog.csdn.net/m0_74421344/article/details/130477776