Springboot 拦截器配置(登陆拦截)

Springboot 拦截器配置(登陆拦截)css

注意这里环境为springboot为2.1版本html


1.编写拦截器实现类,实现接口   HandlerInterceptor,前端

重写里面须要的三个比较经常使用的方法,实现本身的业务逻辑代码java

(就是本身拦截器拦截时作什么处理)web

package com.*.*.interceptor;

import java.io.IOException;

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

import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView;

import com.*.*.*.User;

/**
 * 
 * 
 * @Package: com.*.*.interceptor 
 * @ClassName: AdminInterceptor 
 * @Description:拦截器
 * @author: zk
 * @date: 2019年9月19日 下午2:20:57
 */
public class AdminInterceptor implements  HandlerInterceptor {

    /**
     * 在请求处理以前进行调用(Controller方法调用以前)
     */
    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) {
//        System.out.println("执行了TestInterceptor的preHandle方法");
        try {
            //统一拦截(查询当前session是否存在user)(这里user会在每次登录成功后,写入session)
            User user=(User)request.getSession().getAttribute("USER");
            if(user!=null){
                return true;
            }
            response.sendRedirect(request.getContextPath()+"你的登录页地址");
        } catch (IOException 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方法");
    }
    
}

2.编写拦截器配置文件类并继承  WebMvcConfigurer类,并重写其中的方法  addInterceptors而且在主类上加上注解  @Configurationspring

package com.*.*.config;

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;

import com.*.*.interceptor.AdminInterceptor;

/**
 * 
 * 
 * @Package: com.*.*.config 
 * @ClassName: LoginConfig 
 * @Description:拦截器配置
 * @author: zk
 * @date: 2019年9月19日 下午2:18:35
 */
@Configuration
public class LoginConfig implements WebMvcConfigurer {
    
    @Override
    public void addInterceptors(InterceptorRegistry registry) {
        //注册TestInterceptor拦截器
        InterceptorRegistration registration = registry.addInterceptor(new AdminInterceptor());
        registration.addPathPatterns("/**");                      //全部路径都被拦截
        registration.excludePathPatterns(                         //添加不拦截路径
                                         "你的登录路径",            //登陆
                                         "/**/*.html",            //html静态资源
                                         "/**/*.js",              //js静态资源
                                         "/**/*.css",             //css静态资源
                                         "/**/*.woff",
                                         "/**/*.ttf"
                                         );    
    }
}

这里不被拦截的路径,根据本身需求进行添加,上述主要是关于静态资源方面的后端


到这里后端拦截已经完成springboot

个人项目是先后端分离的,前端使用的LayuiAdmin,借助了LayuiAdmin的前端拦截器进行相关html页面的拦截session


结束前后端分离

相关文章
相关标签/搜索