本文介绍: 拦截器 Interceptor 在 Spring MVC 中的地位等同于 Servlet 规范中的过滤器 Filter,拦截的是处理器执行,由于是全局行为,因此常用于做一些通用的功能,如请求日志打印权限控制等。核心原理:AOP思想。

一、什么拦截器Interceptor

        拦截器 Interceptor 在 Spring MVC 中的地位等同于 Servlet 规范中的过滤器 Filter,拦截的是处理器执行,由于是全局行为,因此常用于做一些通用的功能,如请求日志打印权限控制等。

        核心原理AOP思想

二、拦截器中的三个方法

preHandle预先处理,在目标controller方法执行之前,进行处理

postHandle目标controller方法执行之后,到达指定页面之前进行处理

afterCompletion页面渲染之后进行处理

详细解释这里 

三、SpringBoot加入拦截器

1.Springboot通过实现HandlerInterceptor接口实现拦截器

2.通过WebMvcConfigurer实现一个配置类,再通过@Configuration 注解注入容器

3.指定拦截规则

 以用户登录案例,若用户没有登录session里面没有用户数据,就会转到首页登录页面

1、在正确登录之后,就将reglister保存session中,再次访问页面的时候,登录拦截器可以找到这个reglister对象,就不需要再次拦截到登录界面了。

2、 编写拦截器,实现HandlerInteceptor接口重写内部方法登陆拦截功能需要重写preHandle方法即可

package com.songqiao.InterceptorConfig;

import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.HandlerInterceptor;

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

@Configuration
public class MyInterceptor implements HandlerInterceptor {
    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        Object user = request.getSession().getAttribute("user");
        if(user!=null){
            return true;
        }else {
            request.setAttribute("msg","没有权限,请先登录");
            request.getRequestDispatcher("/login").forward(request,response);
//       重定向两次请求,request生命周期结束获取不到msg     response.sendRedirect(request.getContextPath() + "/login");
            return false;
        }
    }

}

3、注册拦截器,编写一个配置类,使其实现WebMvcConfigurer接口重写其中的addInterceptors方法,将我们写好的拦截器添加进去,并规定要拦截和放行的内容

package com.songqiao.InterceptorConfig;

import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;
@Configuration
public class WebConfig implements WebMvcConfigurer {
    @Override
    public void addInterceptors(InterceptorRegistry registry) {
        registry.addInterceptor(new MyInterceptor())
                .addPathPatterns("/**")
                .excludePathPatterns("/","/loginIn","/signup","/register","/login");
    }
}

即可实现登录拦截功能!

原文地址:https://blog.csdn.net/weixin_52536274/article/details/130565410

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任

如若转载,请注明出处:http://www.7code.cn/show_21684.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱suwngjj01@126.com进行投诉反馈,一经查实,立即删除

发表回复

您的电子邮箱地址不会被公开。 必填项已用 * 标注