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