SpringMVC攔截器超詳細(xì)解讀
1.什么是攔截器
? SpringMVC提供了Intercepter攔截器機(jī)制,類似于Servlet當(dāng)中的Filter過濾器,用于攔截用戶的請求并作出相應(yīng)的處理,比如通過攔截器來進(jìn)行用戶權(quán)限驗(yàn)證或者用來判斷用戶是否登錄。SpringMVC攔截器是可插拔式的設(shè)計(jì),需要某一功能攔截器,就需要在配置文件中應(yīng)用攔截器即可;如果不需要這個(gè)功能攔截器,只需要在配置文件中取消該攔截器即可。
2.攔截器和過濾器有哪些區(qū)別
1.過濾器依賴于servlet,而攔截器技術(shù)屬于SpringMVC
2.過濾器可對所有請求起作用,攔截器只對訪問controller層的請求起作用。
3.過濾器會比攔截器先執(zhí)行。攔截器(Interceptor)是在Servlet和Controller控制器之間執(zhí)行;而過濾器(Filter)是在請求進(jìn)入Tomcat容器之后 但是在請求進(jìn)入Servlet之前執(zhí)行。
3.攔截器方法
- 攔截器的preHandle、postHandle、afterCompletion三個(gè)方法
我們可以看到 HandlerInterceptor接口有三個(gè)方法,分別是preHandle、postHandle、afterCompletion,關(guān)于這三個(gè)方法
- preHandle 方法:該方法在執(zhí)行器方法之前執(zhí)行。返回值為Boolean類型,如果返回false,表示攔截器不再向下執(zhí)行;如果返回true,表示放行,程序向下執(zhí)行(如果后邊沒有其他Interceptor,就會執(zhí)行Controller方法)。所以,此方法可對方法進(jìn)行判斷,決定程序是否繼續(xù)執(zhí)行,或者進(jìn)行一些初始化操作及對請求進(jìn)行預(yù)處理。
- postHandle方法:**該方法在執(zhí)行控制器方法調(diào)用之后,且在返回ModelAndView之前執(zhí)行。**由于該方法會在DispatcherServlet進(jìn)行返回視圖渲染之前被調(diào)用,所以此方法多被用于處理返回的視圖,可通過此方法多被用于處理返回的視圖,可通過此方法對請求域中的模型和視圖做進(jìn)一步的修改。
- afterCompletion方法:該方法在執(zhí)行完控制器之后執(zhí)行。由于是在Controller方法執(zhí)行完畢之后執(zhí)行該方法,所以該方法適合進(jìn)行一些資源清理、記錄日志信息等處理操作。
- 使用單個(gè)攔截器實(shí)現(xiàn)登錄驗(yàn)證
(1)登錄頁:如果賬號密碼正確存入session
package com.qcby.controller; import com.qcby.model.User1; import org.springframework.stereotype.Controller; import org.springframework.ui.Model; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestMethod; import javax.servlet.http.HttpSession; @Controller @RequestMapping("/to") public class LoginController { /** * 跳轉(zhuǎn)到登錄頁 * @return */ @RequestMapping("/toLogin") public String loginPage(){ System.out.println("跳轉(zhuǎn)到登錄頁"); return "login"; } /** * 用戶登錄,成功到主頁,失敗回到登錄頁 * @param user * @param model * @param session * @return */ @RequestMapping(value = "/login",method = RequestMethod.POST) public String login(User1 user, Model model, HttpSession session){ if(user.getUsername() !=null && user.getUsername().equals("admin") && user.getPassword() !=null && user.getPassword().equals("123456")){ System.out.println("用戶登錄功能實(shí)現(xiàn)"); //將用戶添加到session保存 session.setAttribute("user",user); return "suc"; } model.addAttribute("msg","賬戶或密碼錯(cuò)誤,請重新登錄"); return "login"; } }
(2)訪問controller層,則需要通過攔截器的登錄判斷
package com.qcby.config; import org.springframework.web.servlet.HandlerInterceptor; import org.springframework.web.servlet.ModelAndView; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; public class LoginInterceptor implements HandlerInterceptor { @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { //獲取請求的url String url=request.getRequestURI(); if(!url.contains("login")){ //不是登錄請求,判斷有沒有登錄 if(request.getSession().getAttribute("user")!=null){ return true; //說明已經(jīng)登錄,則放行 }else{ request.setAttribute("msg","你還沒有登錄,請登錄。。。"); request.getRequestDispatcher("/html/login.html").forward(request,response); } }else { //登錄請求,放行 return true; } return true; } @Override public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception { } @Override public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception { } }
(3)在springMV.xml文件當(dāng)中配置攔截器
<!--配置攔截器--> <mvc:interceptors> <mvc:interceptor> <mvc:mapping path="/**"/> <!--/**表示所有url--> <bean class="com.qcby.Interceptor.LoginInterceptor"/> </mvc:interceptor> </mvc:interceptors>
4.多個(gè)攔截器的執(zhí)行流程
當(dāng)多個(gè)攔截器同時(shí)工作時(shí),它們的preHandle()方法會按照配置文件中攔截器的配置順序執(zhí)行,而它們的postHandle()方法和afterCompletion()方法則會按照配置順序的反序執(zhí)行。
假設(shè)有兩個(gè)攔截器Interceptor1和interceptor2,并且在配置文件中,Interceptor1攔截器配置在前。
到此這篇關(guān)于SpringMVC攔截器超詳細(xì)解讀的文章就介紹到這了,更多相關(guān)SpringMVC攔截器內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java實(shí)現(xiàn)國產(chǎn)加密算法SM4的示例詳解
這篇文章主要為大家詳細(xì)介紹了Java如何實(shí)現(xiàn)國產(chǎn)加密算法SM4(ECB和CBC兩種模式),文中的示例代碼講解詳細(xì),感興趣的小伙伴可以了解一下2023-01-01java:程序包org.bouncycastle.jce.provider不存在問題及解決
這篇文章主要介紹了java:程序包org.bouncycastle.jce.provider不存在問題及解決方案,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-05-05springboot tomcat的maxHttpFormPostSize參數(shù)示例解析
這篇文章主要介紹了springboot tomcat的maxHttpFormPostSize參數(shù)示例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-08-08spring security登錄成功后跳轉(zhuǎn)回登錄前的頁面
這篇文章主要介紹了spring security登錄成功后跳轉(zhuǎn)回登錄前的頁面,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-09-09Springboot中使用攔截器、過濾器、監(jiān)聽器的流程分析
Javaweb三大組件:servlet、Filter(過濾器)、?Listener(監(jiān)聽器),這篇文章主要介紹了Springboot中使用攔截器、過濾器、監(jiān)聽器的流程分析,感興趣的朋友跟隨小編一起看看吧2023-12-12spring schedule實(shí)現(xiàn)動態(tài)配置執(zhí)行時(shí)間
這篇文章主要介紹了spring schedule實(shí)現(xiàn)動態(tài)配置執(zhí)行時(shí)間,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-11-11Java數(shù)據(jù)結(jié)構(gòu)之簡單的連接點(diǎn)(link)實(shí)現(xiàn)方法示例
這篇文章主要介紹了Java數(shù)據(jù)結(jié)構(gòu)之簡單的連接點(diǎn)(link)實(shí)現(xiàn)方法,涉及java指針指向節(jié)點(diǎn)的相關(guān)使用技巧,需要的朋友可以參考下2017-10-10java web項(xiàng)目實(shí)現(xiàn)文件下載實(shí)例代碼
現(xiàn)在項(xiàng)目里面有個(gè)需求,需要把系統(tǒng)產(chǎn)生的日志文件給下載到本地 先獲取所有的日志文件列表,顯示到界面,選擇一個(gè)日志文件,把文件名傳到后臺2013-09-09maven-surefire-plugin總結(jié)示例詳解
這篇文章主要介紹了maven-surefire-plugin總結(jié),本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-07-07