零基礎(chǔ)入門SpringMVC攔截器的配置與使用
在SpringMVC中 我們說到了攔截器 , 它會在映射處理器(HandleMapping)執(zhí)行時檢查我們
訪問的地址是否配置攔截器 , 在攔截器中實(shí)現(xiàn)一些功能

SpringMVC 定義了攔截器接口 HandlerInterceptor該接口中定義了三個方法,這三個方法的調(diào)用時在 SpringMVC 框架內(nèi)部完成的, 調(diào)用這個三個方法的時候,其參數(shù)的值也是從框架內(nèi)部傳遞進(jìn)來的。
首先我們來看第一個方法 : boolean preHandle()
預(yù)處理方法,實(shí)現(xiàn)處理器(Controller層, 控制器)方法的預(yù)處理,就是在處理器方法執(zhí)行之前這個方法會被行,相當(dāng)于攔截了處理器方法,框架會傳遞請求和響應(yīng)對象給該方法,第三個參數(shù)為被攔截的處理器方法。如果 preHandle 方法返回 true 表示繼續(xù)流程(如調(diào)用下一個攔截器或處理器方法),返回 false 表示流程中斷,不會繼續(xù)調(diào)用其他的攔截器或處理器方法,此時我們需要通過 response 來產(chǎn)生響應(yīng);
意思就是說呢 , 當(dāng)請求到達(dá)我們控制層方法時, 會先進(jìn)入這個方法中, 根據(jù)preHandle() 方法的
返回結(jié)果(true 和 false) 來決定下一步如何執(zhí)行
后兩個方法 : void postHandle() afterCompletion()
首先第一個方法是控制層方法執(zhí)行后會執(zhí)行, 第二個方法時整個請求結(jié)束后執(zhí)行, 因為版本原因, 這兩個方法的使用頻率較低, 所以這里我們做一個了解即可
接著我們?nèi)ゴ罱ㄒ粋€攔截器看看到底是怎么一回事
//自己編寫一個類PreInterceptor 實(shí)現(xiàn) HandlerInterceptor接口 , 重寫preHandle方法
public class PreInterceptor implements HandlerInterceptor {
//此方法返回true ,請求才能順利到達(dá)相應(yīng)的處理方法中,否則會被攔截
@Override
public boolean preHandle(HttpServletRequest request,
HttpServletResponse response, Object handler) throws Exception {
//第三個參數(shù)為目標(biāo)控制器對象
HttpSession session= request.getSession();
//判斷信息是否有效
Admin admin = (Admin) session.getAttribute("admin");
if (admin==null){
response.getWriter().print(202);
return false;
}else {
return true;
}
}
}接著需要去配置文件中配置攔截器
<!--配置攔截器-->
<mvc:interceptors>
<mvc:interceptor>
<!--所有請求都進(jìn)入攔截器-->
<mvc:mapping path="/**"/>
<!--指定哪些請求不進(jìn)入攔截器-->
<mvc:exclude-mapping path="/login/login"/>
<mvc:exclude-mapping path="/css/**"/>
<mvc:exclude-mapping path="/images/**"/>
<mvc:exclude-mapping path="/js/**"/>
<mvc:exclude-mapping path="/**.html"/>
<!--攔截器實(shí)現(xiàn)類-->
<bean id="login" class="com.ff.ssm.util.PreInterceptor"/>
</mvc:interceptor>
</mvc:interceptors>這里我們以后端登錄 的控制器為例
@RestController
@RequestMapping(value = "/login")
public class LoginController {
@Autowired
LoginService loginService;
@PostMapping(value = "/login")
public CommonResult adminLogin(Admin admin, HttpSession session){
CommonResult commonResult;
try {
Admin admin1 = loginService.login(admin);
if(admin1==null){
commonResult=new CommonResult(201,"賬號或密碼錯誤",admin1);
}else {
session.setAttribute("admin",admin1);
commonResult=new CommonResult(200,"登錄成功",admin1);
}
}catch (Exception e){
commonResult=new CommonResult(500,"登錄失敗","");
}
return commonResult;
}
}如上, 前端發(fā)起了登錄請求 , 我們配置了攔截器, 會先進(jìn)入攔截器 , 根據(jù) preHandle() 方法決定
是否可以進(jìn)入到我們具體的登錄方法中
上述控制器例子是將用戶的信息存入了session中 , 我們每次接受前端的請求時, 在攔截器中判斷用戶的信息是否還是有效的 , 有效則放行, 無效則攔截 , 所以前提是我們的登錄請求肯定是不能被攔截的, 因為這時候沒有登錄, 用戶信息為 null ,所以上面我們配置了不攔截登錄請求, 也不去攔截那些請求頁面
以上就是SpringMVC中攔截器的具體功能和實(shí)現(xiàn) , 感謝閱讀
到此這篇關(guān)于零基礎(chǔ)入門SpringMVC攔截器的配置與使用的文章就介紹到這了,更多相關(guān)SpringMVC攔截器內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
springboot2.0以上調(diào)度器配置線程池的實(shí)現(xiàn)
這篇文章主要介紹了springboot2.0以上調(diào)度器配置線程池的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-12-12
Java將GeoHash轉(zhuǎn)化為對應(yīng)的經(jīng)緯度坐標(biāo)實(shí)例代碼
這篇文章主要介紹了Java實(shí)現(xiàn)將GeoHash轉(zhuǎn)化為對應(yīng)的經(jīng)緯度坐標(biāo)的相關(guān)資料,需要的朋友可以參考下2016-01-01
Java Mybatis框架多表操作與注解開發(fā)詳解分析
MyBatis 是一款優(yōu)秀的持久層框架,它支持自定義 SQL、存儲過程以及高級映射。MyBatis 免除了幾乎所有的 JDBC 代碼以及設(shè)置參數(shù)和獲取結(jié)果集的工作。MyBatis 可以通過簡單的 XML 或注解來配置和映射原始類型、接口和 Java POJO為數(shù)據(jù)庫中的記錄2021-10-10
java實(shí)現(xiàn)合并單元格的同時并導(dǎo)出excel示例
這篇文章主要給大家介紹了關(guān)于java實(shí)現(xiàn)合并單元格的同時并導(dǎo)出excel的相關(guān)資料,文中先進(jìn)行了簡單的介紹,之后給出了詳細(xì)的示例代碼,相信對大家具有一定的參考價值,需要的朋友們下面來一起看看吧。2017-03-03
淺談Spring Cloud中的API網(wǎng)關(guān)服務(wù)Zuul
這篇文章主要介紹了淺談Spring Cloud中的API網(wǎng)關(guān)服務(wù)Zuul,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-10-10
SpringBoot項目實(shí)用功能之實(shí)現(xiàn)自定義參數(shù)解析器
這篇文章主要介紹了SpringBoot項目實(shí)用功能之實(shí)現(xiàn)自定義參數(shù)解析器,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-08-08
MyBatis自定義resultMap三種映射關(guān)系示例詳解

