欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

零基礎(chǔ)入門SpringMVC攔截器的配置與使用

 更新時間:2022年04月27日 09:58:00   作者:羨羨ˇ  
Spring?MVC?的攔截器(Interceptor)與?Java?Servlet?的過濾器(Filter)類似,它主要用于攔截用戶的請求并做相應(yīng)的處理,通常應(yīng)用在權(quán)限驗證、記錄請求信息的日志、判斷用戶是否登錄等功能上。本文將代碼演示和文字描述詳解攔截器的原理與使用

 在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)文章

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

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

    這篇文章主要介紹了MyBatis自定義resultMap三種映射關(guān)系,本文通過示例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-08-08
  • 詳解Java-Jackson使用

    詳解Java-Jackson使用

    這篇文章主要介紹了Java-Jackson使用詳解,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-03-03
  • 最新評論