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
結束前後端分離