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