springboot自定義攔截器簡單使用及舉例
1. 自定義攔截器
在springboot中,使用自定義攔截器,只需要將類實現(xiàn)HandlerIntercepter
接口(與原生的filter也基本差不多)。
HandlerIntercepeter源碼:
package org.springframework.web.servlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import org.springframework.lang.Nullable; import org.springframework.web.method.HandlerMethod; public interface HandlerInterceptor { default boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { return true; } default void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, @Nullable ModelAndView modelAndView) throws Exception { } default void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, @Nullable Exception ex) throws Exception { } }
preHandle():當(dāng)某個 url 已經(jīng)匹配到對應(yīng)的 Controller 中的某個方法,且在這個方法執(zhí)行之前 去執(zhí)行。返回 true 則放行,返回 false 則不會向后執(zhí)行。
postHandle():當(dāng)某個 url 已經(jīng)匹配到對應(yīng)的 Controller 中的某個方法,且在執(zhí)行完了該方法,但是在 DispatcherServlet視圖渲染之前。所以在這個方法中有個 ModelAndView 參數(shù),可以在此做一些修改動作。
afterCompletion():在整個請求處理完成后(包括視圖渲染)執(zhí)行,這時做一些資源的清理工作,這個方法只有在 preHandle(……) 被成功執(zhí)行后并且返回 true才會被執(zhí)行。
2. 攔截器登錄驗證的小demo
只有當(dāng)用戶正確登錄以后,才允許用戶去訪問網(wǎng)站的其他頁面和資源,即初始時攔截掉所有請求,除了登錄頁面的請求,登錄成功以后放行訪問其他頁面。
目錄結(jié)構(gòu)如下:
2.1 配置pom.xml
配置pom.xml
<dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-thymeleaf</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-devtools</artifactId> <scope>runtime</scope> <optional>true</optional> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-configuration-processor</artifactId> <optional>true</optional> </dependency> <dependency> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId> <optional>true</optional> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> <scope>test</scope> </dependency> </dependencies> <build> <plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> <configuration> <excludes> <exclude> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId> </exclude> </excludes> </configuration> </plugin> </plugins> </build>
2.2 創(chuàng)建User的bean組件
使用lombok,來快速生成有參無參構(gòu)造器,以及get ,set方法和toString()方法
package com.robin.boot.bean; import lombok.AllArgsConstructor; import lombok.Data; import lombok.NoArgsConstructor; import lombok.ToString; @ToString @NoArgsConstructor @AllArgsConstructor @Data public class User { private String userName; private String password; }
2.3 創(chuàng)建需要的表單頁面以及登錄成功的頁面
index.html:
<!DOCTYPE html> <html lang="en" xmlns:th="http://www.thymeleaf.org"> <head> <meta charset="UTF-8"> <title>登錄頁面</title> </head> <body> <h3 th:text="${msg}">title</h3> <form action="/login" method="post"> <input type="text" name="userName"><br> <input type="password" name="password"><br> <input type="submit" value="登錄"> </form> </body> </html>
show.html:
<!DOCTYPE html> <html lang="en" xmlns:th="http://www.thymeleaf.org"> <head> <meta charset="UTF-8"> <title>顯示頁面</title> </head> <body> <h3 th:text="${msg}">title</h3> 賬號:<p th:text="${loginUser.userName}">賬號xxx</p> 密碼:<p th:text="${loginUser.password}">密碼xxx</p> </body> </html>
2.4 編寫controller映射關(guān)系
package com.robin.boot.controller; import com.robin.boot.bean.User; import org.springframework.stereotype.Controller; import org.springframework.ui.Model; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.PostMapping; @Controller public class LoginController { @PostMapping("/login") public String login(User user, Model model){ System.out.println(user); if ("robin".equals(user.getUserName())&&"123456".equals(user.getPassword())){ model.addAttribute("loginUser",user); return "show"; }else{ model.addAttribute("msg","登錄失敗,請檢查賬號密碼信息.."); return "index"; } } }
2.5 自定義攔截器類,實現(xiàn)intercepetor接口
package com.robin.boot.interceptor; import lombok.extern.slf4j.Slf4j; import org.springframework.web.servlet.HandlerInterceptor; import org.springframework.web.servlet.ModelAndView; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import javax.servlet.http.HttpSession; @Slf4j public class LoginInterceptor implements HandlerInterceptor { // 目標(biāo)方法執(zhí)行之前 @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { // 攔截請求輸出 String requestURI = request.getRequestURI(); log.info("攔截了請求{}",requestURI); // 登錄檢查邏輯,是否登錄,登錄成功以后放行資源,未登錄則攔截資源 HttpSession session = request.getSession(); Object loginUser = session.getAttribute("loginUser"); if (loginUser!=null){ // 登錄成功放行資源 return true; }else{ // 提示錯誤信息 request.setAttribute("msg","請先登錄!"); // 請求轉(zhuǎn)發(fā) request.getRequestDispatcher("/").forward(request,response); // 未登錄攔截資源 return false; } } // 目標(biāo)方法執(zhí)行完畢 @Override public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception { log.info("postHandle執(zhí)行{}",modelAndView); } // 頁面渲染以后 @Override public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception { log.info("afterCompletion執(zhí)行異常{}",ex); } }
2.6注冊添加攔截器,自定義springboot配置類
通過addInterceptors(InterceptorRegistry registry)
方法,使用registry.addInterceptor()
將自定義攔截器注冊。
并且通過InterceptorRegistration.addPathPatterns()
方法添加攔截的請求,InterceptorRegistration.excludePathPatterns()
方法放行請求。
package com.robin.boot.config; import com.robin.boot.interceptor.LoginInterceptor; import org.springframework.context.annotation.Configuration; import org.springframework.web.servlet.config.annotation.InterceptorRegistry; import org.springframework.web.servlet.config.annotation.WebMvcConfigurer; // 自定義springboot配置類 @Configuration public class MyWebConfig implements WebMvcConfigurer { // 添加注冊攔截器 @Override public void addInterceptors(InterceptorRegistry registry) { registry.addInterceptor(new LoginInterceptor()) .addPathPatterns("/**") // 攔截所有請求 .excludePathPatterns("/","/login"); // 放行 / 和 /login請求, // 因為例子寫的比較簡單 // .excludePathPatterns("/","/login","/css/**","/js/**","/fonts/**","/images/**"); 平常可以寫這樣 } }
2.7 運行測試
訪問首頁:
輸入錯誤的賬號信息:
直接通過地址欄訪問show.html,http://localhost:8080/show.html
,攔截器發(fā)送提示信息并請求轉(zhuǎn)發(fā)到index.html
,因為是請求轉(zhuǎn)發(fā),所有地址欄不會發(fā)生改變。
輸入正確的賬號信息,成功訪問:
總結(jié)
到此這篇關(guān)于springboot自定義攔截器簡單使用及舉例的文章就介紹到這了,更多相關(guān)springboot自定義攔截器內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
關(guān)于Hadoop中Spark?Streaming的基本概念
這篇文章主要介紹了關(guān)于Hadoop中Spark?Streaming的基本概念,Spark?Streaming是構(gòu)建在Spark上的實時計算框架,它擴展了Spark處理大規(guī)模流式數(shù)據(jù)的能力,Spark?Streaming可結(jié)合批處理和交互式查詢,需要的朋友可以參考下2023-07-07Spring Boot實現(xiàn)郵件服務(wù)(附:常見郵箱的配置)
這篇文章主要給大家介紹了關(guān)于Spring Boot實現(xiàn)郵件服務(wù)的相關(guān)資料,文中還附上了常見郵箱的配置,通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2018-12-12java開發(fā)web前端cookie session及token會話機制詳解
如果把人體比作一個web系統(tǒng)的話,cookie、session和token就好像人體的經(jīng)絡(luò)和血管一樣,而web系統(tǒng)中的數(shù)據(jù),就好像人體的血液一樣。血液依靠著血管在人體內(nèi)流動,就如數(shù)據(jù)根據(jù)cookie和session機制在web系統(tǒng)中流動一樣2021-10-10Spring?JPA使用CriteriaBuilder動態(tài)構(gòu)造查詢方式
這篇文章主要介紹了Spring?JPA使用CriteriaBuilder動態(tài)構(gòu)造查詢方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-12-12java?JVM方法分派模型靜態(tài)分派動態(tài)分派全面講解
這篇文章主要為大家介紹了java?JVM方法分派模型靜態(tài)分派動態(tài)分派全面講解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-06-06