各位小伙伴
咱們繼續(xù)學(xué)習(xí)新知識(shí)
今天要分享的就是
攔截器
不知道小伙伴們平時(shí)上網(wǎng)的時(shí)候有沒(méi)有注意到,尤其是上網(wǎng)購(gòu)物的時(shí)候,不登錄賬號(hào),就無(wú)法訪問(wèn)一些功能頁(yè)面,比如你不登錄賬號(hào),就沒(méi)法查看購(gòu)物車?yán)锩嬗惺裁次锲?/b>.這就是攔截器起到的作用.那么今天我們就來(lái)給之前的項(xiàng)目添加一個(gè)攔截器.
攔截器
攔截器的概念
SpringMVC 中的?Interceptor 攔截器的主要作用就是攔截用戶的 url 請(qǐng)求,并在執(zhí)行 handler 方法的前中后加入某些特殊請(qǐng)求,類似于 servlet 里面的過(guò)濾器.
開(kāi)發(fā)攔截器
定義一個(gè)攔截類,實(shí)現(xiàn) HandlerInterceptor 接口,這里面一共有三個(gè)方法,?
preHandle 方法:
在 handler 方法執(zhí)行之前,運(yùn)行里面的代碼,可以用于用戶的登錄驗(yàn)證.
postHandle 方法:
在 handler 方法執(zhí)行中,返回 ModelAndView 之前運(yùn)行里面的代碼,可以向頁(yè)面提供共用的數(shù)據(jù).
afterCompletion 方法:
在 handler 方法執(zhí)行之后,運(yùn)行里面的代碼,可以進(jìn)行異常處理,計(jì)算執(zhí)行時(shí)間,記錄日志.
在 springmvc.xml 里面配置攔截器
運(yùn)行一下,頁(yè)面有點(diǎn)丑就不展示了,直接看后臺(tái)控制臺(tái)的輸出內(nèi)容,可以看出我們的三個(gè)方法的運(yùn)行順序,和我們之前說(shuō)的是一樣的.
下面我們來(lái)測(cè)試多個(gè)攔截器的運(yùn)行效果,再編寫(xiě)一個(gè)攔截器,(其實(shí)就是之前的代碼復(fù)制一下,改個(gè)名字.)
千萬(wàn)不要忘了要配置springMVC.xml
發(fā)布項(xiàng)目,查看控制臺(tái)的輸出內(nèi)容
注意:
1)當(dāng) preHandler 方法返回 false 時(shí),其余的的兩個(gè)方法都不執(zhí)行,而且 handler 也不會(huì)執(zhí)行
2)攔截器里面的 preHandler ,postHandler 和 afterCompletion 方法是按順序依次執(zhí)行的
3)當(dāng)有多個(gè)攔截器存在時(shí),如果有任意一個(gè)攔截器的 preHandler 方法返回 false ,則剩下的都不執(zhí)行
4)如果多個(gè)攔截器同時(shí)運(yùn)行(preHandler方法返回true),那么 preHanlder 方法是按順序執(zhí)行,而其余兩個(gè)方法(postHandler 和 afterCompletion)是倒序執(zhí)行
5)攔截器的執(zhí)行順序是按照在 springmvc 配置文件中的位置來(lái)順序執(zhí)行的
攔截器實(shí)戰(zhàn)
需求:
只有登陸的用戶才有權(quán)限訪問(wèn)系統(tǒng)中的功能
思路:
1)在登陸成功后,將用戶信息放入 session.
2)編寫(xiě)用戶登錄攔截器的代碼,獲取 session 中的 loginName,若 loginName 不為空則證明用戶成功登陸,preHandle 方法返回 true ,否則返回 false.
在這里要注意一下,開(kāi)放 login.do 的 url 訪問(wèn)權(quán)限,不然就沒(méi)法驗(yàn)證用戶登錄,沒(méi)法把用戶信息保存到 session 中. ?
配置 springMVC.xml
除了登陸驗(yàn)證的 url 請(qǐng)求,其他 url 請(qǐng)求,在攔截器的 preHandler 方法里面判斷 session 是否有用戶信息,如果有,則放行通過(guò),如果沒(méi)有 ,跳轉(zhuǎn)到登陸頁(yè)面,提示用戶登陸.
各位小伙伴
今天的分享就到這里了
拜拜