零基礎(chǔ)入門SpringMVC攔截器的配置與使用
在SpringMVC中 我們說到了攔截器 , 它會在映射處理器(HandleMapping)執(zhí)行時檢查我們
訪問的地址是否配置攔截器 , 在攔截器中實現(xiàn)一些功能
SpringMVC 定義了攔截器接口 HandlerInterceptor該接口中定義了三個方法,這三個方法的調(diào)用時在 SpringMVC 框架內(nèi)部完成的, 調(diào)用這個三個方法的時候,其參數(shù)的值也是從框架內(nèi)部傳遞進(jìn)來的。
首先我們來看第一個方法 : boolean preHandle()
預(yù)處理方法,實現(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 實現(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"/> <!--攔截器實現(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中攔截器的具體功能和實現(xiàn) , 感謝閱讀
到此這篇關(guān)于零基礎(chǔ)入門SpringMVC攔截器的配置與使用的文章就介紹到這了,更多相關(guān)SpringMVC攔截器內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
springboot2.0以上調(diào)度器配置線程池的實現(xiàn)
這篇文章主要介紹了springboot2.0以上調(diào)度器配置線程池的實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-12-12Java將GeoHash轉(zhuǎn)化為對應(yīng)的經(jīng)緯度坐標(biāo)實例代碼
這篇文章主要介紹了Java實現(xiàn)將GeoHash轉(zhuǎn)化為對應(yīng)的經(jīng)緯度坐標(biāo)的相關(guān)資料,需要的朋友可以參考下2016-01-01Java Mybatis框架多表操作與注解開發(fā)詳解分析
MyBatis 是一款優(yōu)秀的持久層框架,它支持自定義 SQL、存儲過程以及高級映射。MyBatis 免除了幾乎所有的 JDBC 代碼以及設(shè)置參數(shù)和獲取結(jié)果集的工作。MyBatis 可以通過簡單的 XML 或注解來配置和映射原始類型、接口和 Java POJO為數(shù)據(jù)庫中的記錄2021-10-10java實現(xiàn)合并單元格的同時并導(dǎo)出excel示例
這篇文章主要給大家介紹了關(guān)于java實現(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-10SpringBoot項目實用功能之實現(xiàn)自定義參數(shù)解析器
這篇文章主要介紹了SpringBoot項目實用功能之實現(xiàn)自定義參數(shù)解析器,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-08-08

MyBatis自定義resultMap三種映射關(guān)系示例詳解