一、攔截器
??Spring Web MVC 的處理器攔截器類(lèi)似于Servlet 開(kāi)發(fā)中的過(guò)濾器Filter,用于對(duì)處理器進(jìn)行預(yù)處理和后處理。
二、定義攔截器
實(shí)現(xiàn)HandlerInterceptor接口
public class LogInterceptor implements HandlerInterceptor{
/**
* controller執(zhí)行后且視圖返回后調(diào)用此方法
* 這里可得到執(zhí)行controller時(shí)的異常信息
* 這里可記錄操作日志爵赵,資源清理等
*/
public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object arg2, Exception arg3)
throws Exception {
}
/**
* controller執(zhí)行后但未返回視圖前調(diào)用此方法
* 這里可在返回用戶(hù)前對(duì)模型數(shù)據(jù)進(jìn)行加工處理,比如這里加入公用信息以便頁(yè)面顯示
*/
public void postHandle(HttpServletRequest request, HttpServletResponse response, Object arg2, ModelAndView arg3)
throws Exception {
}
/**
* controller執(zhí)行前調(diào)用此方法
* 返回true表示繼續(xù)執(zhí)行慢蜓,返回false中止執(zhí)行
* 這里可以加入登錄校驗(yàn)亚再、權(quán)限攔截等
*/
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object arg2) throws Exception {
return false;
}
}
三、攔截器配置
- 針對(duì)某種mapping配置攔截器
<bean
class="org.springframework.web.servlet.handler.BeanNameUrlHandlerMapping">
<property name="interceptors">
<list>
<ref bean="logInterceptor" />
</list>
</property>
</bean>
<bean id="logInterceptor" class="com.neuedu.interceptor.LogInterceptor" />
- mapping配置全局?jǐn)r截器
<!--攔截器 -->
<mvc:interceptors>
<!--多個(gè)攔截器,順序執(zhí)行 -->
<mvc:interceptor>
<mvc:mapping path="/**"/>
<bean class="com.neuedu.interceptor.HandlerInterceptorLog"></bean>
</mvc:interceptor>
<mvc:interceptor>
<mvc:mapping path="/**"/>
<bean class="com.neuedu.interceptor.HandlerInterceptorLogin"></bean>
</mvc:interceptor>
</mvc:interceptors>
- 日志攔截器
public class HandlerInterceptorLog implements HandlerInterceptor{
public void afterCompletion(HttpServletRequest request,
HttpServletResponse response, Object arg2, Exception arg3)
throws Exception {
System.out.println("日志攔截器后……");
}
public void postHandle(HttpServletRequest request,
HttpServletResponse response, Object arg2, ModelAndView arg3)
throws Exception {
System.out.println("控制器已執(zhí)行晨抡,但視圖未返回……");
}
public boolean preHandle(HttpServletRequest request,
HttpServletResponse response, Object arg2) throws Exception {
System.out.println("日志攔截器前……");
return true;
}
}
- 登錄攔截器
1) 用戶(hù)登陸 controller
// 登陸提交
// userid:用戶(hù)賬號(hào)氛悬,pwd:密碼
@RequestMapping("/login")
public String login(HttpSession session, String userid, String
pwd) throws Exception {
// 向session記錄用戶(hù)身份信息
session.setAttribute("activeUser", userid);
return "redirect:order/itemsList";
}
// 退出
@RequestMapping("/logout")
public String logout(HttpSession session) throws Exception {
// session過(guò)期
session.invalidate();
return "redirect:login";
}
- 攔截器
public class LoginInterceptor implements HandlerInterceptor{
// 進(jìn)入 Handler方法之前執(zhí)行
// 用于身份認(rèn)證则剃、身份授權(quán)
// 比如身份認(rèn)證,如果認(rèn)證通過(guò)表示當(dāng)前用戶(hù)沒(méi)有登陸如捅,需要此方法攔截不再向下執(zhí)行
@Override
public boolean preHandle(HttpServletRequest request,
HttpServletResponse response, Object handler) throws
Exception {
// 獲取請(qǐng)求的url
String url = request.getRequestURI();
// 判斷url是否是公開(kāi) 地址(實(shí)際使用時(shí)將公開(kāi) 地址配置配置文件中)
// 這里公開(kāi)地址是登陸提交的地址
if(url.indexOf("login")>=0){
// 如果進(jìn)行登陸提交棍现,放行
return true;
}
// 判斷session
HttpSession session = request.getSession();
// 從session中取出用戶(hù)身份信息
String username = (String)
session.getAttribute("username");
if(username != null){
// 身份存在,放行
return true;
}
// 執(zhí)行這里表示用戶(hù)身份需要認(rèn)證镜遣,跳轉(zhuǎn)登陸頁(yè)面
request.getRequestDispatcher("/WEBINF/views/login.jsp").forward(request, response);
// return false表示攔截己肮,不向下執(zhí)行
// return true表示放行
return false;
}
// 進(jìn)入Handler方法之后,返回modelAndView之前執(zhí)行
// 應(yīng)用場(chǎng)景從modelAndView出發(fā):將公用的模型數(shù)據(jù)(比如菜單導(dǎo)航)在這里傳到
視圖悲关,也可以在這里統(tǒng)一指定視圖
@Override
public void postHandle(HttpServletRequest request,
HttpServletResponse response, Object handler,
ModelAndView modelAndView) throws Exception {
System.out.println("返回?cái)?shù)據(jù)……");
}
// 執(zhí)行Handler完成執(zhí)行此方法
// 應(yīng)用場(chǎng)景:統(tǒng)一異常處理谎僻,統(tǒng)一日志處理
@Override
public void afterCompletion(HttpServletRequest request,
HttpServletResponse response, Object handler, Exception
ex)
throws Exception {
System.out.println("日志統(tǒng)一處理");
}
}