Java Spring攔截器案例詳解
springmvc提供了攔截器,類似于過濾器,他將在我們的請(qǐng)求具體出來之前先做檢查,有權(quán)決定接下來是否繼續(xù),對(duì)我們的請(qǐng)求進(jìn)行加工。攔截器,可以設(shè)計(jì)多個(gè)。
通過實(shí)現(xiàn)handlerunterceptor,這是個(gè)接口
定義了非常重要的三個(gè)方法:
后置處理
前置處理
完成處理
案例一:通過攔截器實(shí)現(xiàn)方法耗時(shí)統(tǒng)計(jì)與警告
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;/*** 方法耗時(shí)統(tǒng)計(jì)攔截器*/public class MethodTimerInterceptor implements HandlerInterceptor { private static final Logger LOGGER=Logger.getLogger(MethodTimerInterceptor.class); //前置功能, 開始到結(jié)束,兩個(gè)點(diǎn)減法 @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {//定義開始時(shí)間long start = System.currentTimeMillis();//2.將其存到請(qǐng)求域當(dāng)中request.setAttribute('start',start);//記錄請(qǐng)求日志LOGGER.info(request.getRequestURI()+',請(qǐng)求到達(dá)');//3,返回true,才會(huì)找下一個(gè)攔截器,如果沒有下一個(gè)攔截器,則去Controllerreturn true; } @Override public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {//1,取出startlong start = (long) request.getAttribute('start');//2,得到endlong end =System.currentTimeMillis();//3,記錄耗時(shí)long spendTime = end-start;if (spendTime>2000){ LOGGER.warn('方法耗時(shí)嚴(yán)重,請(qǐng)及時(shí)處理,耗時(shí):'+spendTime);}else { LOGGER.info('方法耗時(shí)'+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>
案例二:會(huì)話攔截器
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); //檢查當(dāng)前會(huì)話是否有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)限,請(qǐng)先登錄'); return false;}if(user instanceof User){ //再去數(shù)據(jù)庫檢查其身份對(duì)不對(duì),是否凍結(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('請(qǐng)先登錄'); 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é)點(diǎn)之下即可。
攔截器執(zhí)行順序問題
如果有N個(gè)攔截器,并且都能攔截到某個(gè)URI的時(shí)候,執(zhí)行順序問題,
在springmvc當(dāng)中攔截器定義的順序是有關(guān)系的。配置在前面的優(yōu)先攔截,按照順序來
攔截器與過濾器的比較
相似
1,都有優(yōu)先處理請(qǐng)求的權(quán)利,都可以決定是否將請(qǐng)求轉(zhuǎn)移到請(qǐng)求的實(shí)際處理的控制器處。2,都可以對(duì)請(qǐng)求或者會(huì)話當(dāng)中的數(shù)據(jù)進(jìn)行加工。不同
1, 攔截器可以做前置處理也可以做后置處理,還可以進(jìn)行完成處理,控制的 更加細(xì)致,而過濾器只負(fù)責(zé)前面的過濾行為而已。2, 過濾器優(yōu)先執(zhí)行,還是攔截器優(yōu)先呢?----------過濾器優(yōu)先。3,過濾器是servlet規(guī)范里面的組件。4, 攔截器都是框架自己而外添加的組件。
到此這篇關(guān)于Java Spring攔截器案例詳解的文章就介紹到這了,更多相關(guān)Java Spring攔截器內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. asp(vbs)Rs.Open和Conn.Execute的詳解和區(qū)別及&H0001的說明2. CSS hack用法案例詳解3. ASP 處理JSON數(shù)據(jù)的實(shí)現(xiàn)代碼4. PHP設(shè)計(jì)模式中工廠模式深入詳解5. 用css截取字符的幾種方法詳解(css排版隱藏溢出文本)6. asp中response.write("中文")或者js中文亂碼問題7. 將properties文件的配置設(shè)置為整個(gè)Web應(yīng)用的全局變量實(shí)現(xiàn)方法8. ThinkPHP5實(shí)現(xiàn)JWT Token認(rèn)證的過程(親測(cè)可用)9. ASP 信息提示函數(shù)并作返回或者轉(zhuǎn)向10. jsp網(wǎng)頁實(shí)現(xiàn)貪吃蛇小游戲
