SpringMVC攔截器超詳細解讀

1.什麼是攔截器

​ SpringMVC提供瞭Intercepter攔截器機制,類似於Servlet當中的Filter過濾器,用於攔截用戶的請求並作出相應的處理,比如通過攔截器來進行用戶權限驗證或者用來判斷用戶是否登錄。SpringMVC攔截器是可插拔式的設計,需要某一功能攔截器,就需要在配置文件中應用攔截器即可;如果不需要這個功能攔截器,隻需要在配置文件中取消該攔截器即可。

2.攔截器和過濾器有哪些區別

1.過濾器依賴於servlet,而攔截器技術屬於SpringMVC

2.過濾器可對所有請求起作用,攔截器隻對訪問controller層的請求起作用。

3.過濾器會比攔截器先執行。攔截器(Interceptor)是在Servlet和Controller控制器之間執行;而過濾器(Filter)是在請求進入Tomcat容器之後 但是在請求進入Servlet之前執行。

3.攔截器方法

  1. 攔截器的preHandle、postHandle、afterCompletion三個方法

我們可以看到 HandlerInterceptor接口有三個方法,分別是preHandle、postHandle、afterCompletion,關於這三個方法

  • preHandle 方法:該方法在執行器方法之前執行。返回值為Boolean類型,如果返回false,表示攔截器不再向下執行;如果返回true,表示放行,程序向下執行(如果後邊沒有其他Interceptor,就會執行Controller方法)。所以,此方法可對方法進行判斷,決定程序是否繼續執行,或者進行一些初始化操作及對請求進行預處理。
  • postHandle方法:**該方法在執行控制器方法調用之後,且在返回ModelAndView之前執行。**由於該方法會在DispatcherServlet進行返回視圖渲染之前被調用,所以此方法多被用於處理返回的視圖,可通過此方法多被用於處理返回的視圖,可通過此方法對請求域中的模型和視圖做進一步的修改。
  • afterCompletion方法:該方法在執行完控制器之後執行。由於是在Controller方法執行完畢之後執行該方法,所以該方法適合進行一些資源清理、記錄日志信息等處理操作。
  1. 使用單個攔截器實現登錄驗證

(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>

4.多個攔截器的執行流程

當多個攔截器同時工作時,它們的preHandle()方法會按照配置文件中攔截器的配置順序執行,而它們的postHandle()方法和afterCompletion()方法則會按照配置順序的反序執行。

假設有兩個攔截器Interceptor1和interceptor2,並且在配置文件中,Interceptor1攔截器配置在前。

到此這篇關於SpringMVC攔截器超詳細解讀的文章就介紹到這瞭,更多相關SpringMVC攔截器內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!

推薦閱讀: