Springboot 攔截器配置(登錄攔截)


Springboot 攔截器配置(登錄攔截)

注意這里環境為springboot為2.1版本


1.編寫攔截器實現類,實現接口   HandlerInterceptor,

重寫里面需要的三個比較常用的方法,實現自己的業務邏輯代碼

(就是自己攔截器攔截時做什么處理)

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並且在主類上加上注解  @Configuration

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"
                                         );    
    }
}

這里不被攔截的路徑,根據自己需求進行添加,上述主要是關於靜態資源方面的


到這里后端攔截已經完成

我的項目是前后端分離的,前端使用的LayuiAdmin,借助了LayuiAdmin的前端攔截器進行相關html頁面的攔截


結束


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM