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():當某個 url 已經(jīng)匹配到對應(yīng)的 Controller 中的某個方法,且在這個方法執(zhí)行之前 去執(zhí)行。返回 true 則放行,返回 false 則不會向后執(zhí)行。
postHandle():當某個 url 已經(jīng)匹配到對應(yīng)的 Controller 中的某個方法,且在執(zhí)行完了該方法,但是在 DispatcherServlet視圖渲染之前。所以在這個方法中有個 ModelAndView 參數(shù),可以在此做一些修改動作。
afterCompletion():在整個請求處理完成后(包括視圖渲染)執(zhí)行,這時做一些資源的清理工作,這個方法只有在 preHandle(……) 被成功執(zhí)行后并且返回 true才會被執(zhí)行。
2. 攔截器登錄驗證的小demo
只有當用戶正確登錄以后,才允許用戶去訪問網(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 {
// 目標方法執(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;
}
}
// 目標方法執(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-07
Spring Boot實現(xiàn)郵件服務(wù)(附:常見郵箱的配置)
這篇文章主要給大家介紹了關(guān)于Spring Boot實現(xiàn)郵件服務(wù)的相關(guān)資料,文中還附上了常見郵箱的配置,通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2018-12-12
java開發(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-10
Spring?JPA使用CriteriaBuilder動態(tài)構(gòu)造查詢方式
這篇文章主要介紹了Spring?JPA使用CriteriaBuilder動態(tài)構(gòu)造查詢方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-12-12
java?JVM方法分派模型靜態(tài)分派動態(tài)分派全面講解
這篇文章主要為大家介紹了java?JVM方法分派模型靜態(tài)分派動態(tài)分派全面講解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-06-06

