您好,登錄后才能下訂單哦!
這篇文章主要介紹了SpringMVC攔截器應用實例分析的相關知識,內容詳細易懂,操作簡單快捷,具有一定借鑒價值,相信大家閱讀完這篇SpringMVC攔截器應用實例分析文章都會有所收獲,下面我們一起來看看吧。
SpringMVC提供了Intercepter攔截器機制,類似于Servlet當中的Filter過濾器,用于攔截用戶的請求并作出相應的處理,比如通過攔截器來進行用戶權限驗證或者用來判斷用戶是否登錄。SpringMVC攔截器是可插拔式的設計,需要某一功能攔截器,就需要在配置文件中應用攔截器即可;如果不需要這個功能攔截器,只需要在配置文件中取消該攔截器即可。
1.過濾器依賴于servlet,而攔截器技術屬于SpringMVC
2.過濾器可對所有請求起作用,攔截器只對訪問controller層的請求起作用。
3.過濾器會比攔截器先執行。攔截器(Interceptor)是在Servlet和Controller控制器之間執行;而過濾器(Filter)是在請求進入Tomcat容器之后 但是在請求進入Servlet之前執行。
攔截器的preHandle、postHandle、afterCompletion三個方法
我們可以看到 HandlerInterceptor接口有三個方法,分別是preHandle、postHandle、afterCompletion,關于這三個方法
preHandle 方法:該方法在執行器方法之前執行。返回值為Boolean類型,如果返回false,表示攔截器不再向下執行;如果返回true,表示放行,程序向下執行(如果后邊沒有其他Interceptor,就會執行Controller方法)。所以,此方法可對方法進行判斷,決定程序是否繼續執行,或者進行一些初始化操作及對請求進行預處理。
postHandle方法:**該方法在執行控制器方法調用之后,且在返回ModelAndView之前執行。**由于該方法會在DispatcherServlet進行返回視圖渲染之前被調用,所以此方法多被用于處理返回的視圖,可通過此方法多被用于處理返回的視圖,可通過此方法對請求域中的模型和視圖做進一步的修改。
afterCompletion方法:該方法在執行完控制器之后執行。由于是在Controller方法執行完畢之后執行該方法,所以該方法適合進行一些資源清理、記錄日志信息等處理操作。
使用單個攔截器實現登錄驗證
(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 { /** * 跳轉到登錄頁 * @return */ @RequestMapping("/toLogin") public String loginPage(){ System.out.println("跳轉到登錄頁"); 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("用戶登錄功能實現"); //將用戶添加到session保存 session.setAttribute("user",user); return "suc"; } model.addAttribute("msg","賬戶或密碼錯誤,請重新登錄"); 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; //說明已經登錄,則放行 }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文件當中配置攔截器
<!--配置攔截器--> <mvc:interceptors> <mvc:interceptor> <mvc:mapping path="/**"/> <!--/**表示所有url--> <bean class="com.qcby.Interceptor.LoginInterceptor"/> </mvc:interceptor> </mvc:interceptors>
當多個攔截器同時工作時,它們的preHandle()方法會按照配置文件中攔截器的配置順序執行,而它們的postHandle()方法和afterCompletion()方法則會按照配置順序的反序執行。
假設有兩個攔截器Interceptor1和interceptor2,并且在配置文件中,Interceptor1攔截器配置在前。
關于“SpringMVC攔截器應用實例分析”這篇文章的內容就介紹到這里,感謝各位的閱讀!相信大家對“SpringMVC攔截器應用實例分析”知識都有一定的了解,大家如果還想學習更多知識,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。