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-03
java連接postgresql數(shù)據(jù)庫代碼及maven配置方式
這篇文章主要介紹了java連接postgresql數(shù)據(jù)庫代碼及maven配置方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-09-09
快速解決SpringMVC @RequestBody 用map接收請求參數(shù)的問題
今天小編就為大家分享快速解決SpringMVC @RequestBody 用map接收請求參數(shù)的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-08-08
SpringBoot實現(xiàn)前端驗證碼圖片生成和校驗
這篇文章主要為大家詳細介紹了SpringBoot實現(xiàn)前端驗證碼圖片生成和校驗,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-02-02

