Java Spring攔截器案例詳解
springmvc提供了攔截器,類似于過濾器,他將在我們的請求具體出來之前先做檢查,有權(quán)決定接下來是否繼續(xù),對我們的請求進行加工。
攔截器,可以設(shè)計多個。
通過實現(xiàn)handlerunterceptor,這是個接口
定義了非常重要的三個方法:
后置處理
前置處理
完成處理
案例一:
通過攔截器實現(xiàn)方法耗時統(tǒng)計與警告
package com.xy.interceptors; import org.springframework.web.servlet.HandlerInterceptor; import org.springframework.web.servlet.ModelAndView; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import org.apache.log4j.Logger; /** * 方法耗時統(tǒng)計攔截器 */ public class MethodTimerInterceptor implements HandlerInterceptor { private static final Logger LOGGER=Logger.getLogger(MethodTimerInterceptor.class); //前置功能, 開始到結(jié)束,兩個點減法 @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { //定義開始時間 long start = System.currentTimeMillis(); //2.將其存到請求域當中 request.setAttribute("start",start); //記錄請求日志 LOGGER.info(request.getRequestURI()+",請求到達"); //3,返回true,才會找下一個攔截器,如果沒有下一個攔截器,則去Controller return true; } @Override public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception { //1,取出start long start = (long) request.getAttribute("start"); //2,得到end long end =System.currentTimeMillis(); //3,記錄耗時 long spendTime = end-start; if (spendTime>2000){ LOGGER.warn("方法耗時嚴重,請及時處理,耗時:"+spendTime); }else { LOGGER.info("方法耗時"+spendTime+"毫秒,正常"); } } @Override public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception { } }
springmvc的配置
<!--攔截器的配置--> <mvc:interceptors> <mvc:interceptor> <!-- --> <mvc:mapping path="/**/*"/> <bean class="com.xy.interceptors.MethodTimerInterceptor"> </bean> </mvc:interceptor> </mvc:interceptors>
案例二:會話攔截器
package com.xy.interceptors; import com.xy.pojo.User; import org.apache.log4j.Logger; import org.springframework.web.servlet.HandlerInterceptor; import org.springframework.web.servlet.ModelAndView; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; public class SessionInterceptor implements HandlerInterceptor { private static final Logger LOGGER=Logger.getLogger(SessionInterceptor.class); //檢查當前會話是否有User,如果有則放行,沒有則攔截 @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { Object user = request.getSession().getAttribute("SESSION_USER"); if (user==null){ LOGGER.warn("您不具備權(quán)限,請先登錄"); return false; } if(user instanceof User){ //再去數(shù)據(jù)庫檢查其身份對不對,是否凍結(jié)。。。 User user1 = (User) user; user1.setPwd(null); request.getSession().setAttribute("SESSION_USER",user1); LOGGER.info(user1.getName()+"處于登錄狀態(tài),可以執(zhí)行操作"); return true; }else { LOGGER.warn("請先登錄"); return false; } } @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 { } }
springMvc配置
<!--攔截器的配置--> <mvc:interceptors> <!--只想攔截/user2/**/* 還需要開放登錄權(quán)限 --> <mvc:interceptor> <mvc:mapping path="/user2/**/*"/> <!--排除登錄的URI--> <mvc:exclude-mapping path="/user2/login"></mvc:exclude-mapping> <bean class="com.xy.interceptors.SessionInterceptor"></bean> </mvc:interceptor> </mvc:interceptors>
將其配置在mvc:interceptors節(jié)點之下即可。
攔截器執(zhí)行順序問題
如果有N個攔截器,并且都能攔截到某個URI的時候,執(zhí)行順序問題,
在springmvc當中攔截器定義的順序是有關(guān)系的。配置在前面的優(yōu)先攔截,按照順序來
攔截器與過濾器的比較
相似
1,都有優(yōu)先處理請求的權(quán)利,都可以決定是否將請求轉(zhuǎn)移到請求的實際處理的控制器處。
2,都可以對請求或者會話當中的數(shù)據(jù)進行加工。
不同
1, 攔截器可以做前置處理也可以做后置處理,還可以進行完成處理,控制的 更加細致,而過濾器只負責前面的過濾行為而已。
2, 過濾器優(yōu)先執(zhí)行,還是攔截器優(yōu)先呢?----------過濾器優(yōu)先。
3,過濾器是servlet規(guī)范里面的組件。
4, 攔截器都是框架自己而外添加的組件。
到此這篇關(guān)于Java Spring攔截器案例詳解的文章就介紹到這了,更多相關(guān)Java Spring攔截器內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java的Spring框架中實現(xiàn)發(fā)送郵件功能的核心代碼示例
這篇文章主要介紹了Java的Spring框架中實現(xiàn)發(fā)送郵件功能的核心代碼示例,包括發(fā)送帶附件的郵件功能的實現(xiàn),需要的朋友可以參考下2016-03-03java連接postgresql數(shù)據(jù)庫代碼及maven配置方式
這篇文章主要介紹了java連接postgresql數(shù)據(jù)庫代碼及maven配置方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-09-09快速解決SpringMVC @RequestBody 用map接收請求參數(shù)的問題
今天小編就為大家分享快速解決SpringMVC @RequestBody 用map接收請求參數(shù)的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-08-08SpringBoot實現(xiàn)前端驗證碼圖片生成和校驗
這篇文章主要為大家詳細介紹了SpringBoot實現(xiàn)前端驗證碼圖片生成和校驗,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-02-02