一、编写拦截器类实现HandlerInterceptor
package cn.interceptor;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView;
/**
* 当请求来的时候,先经过applyPreHandle,内部会按顺序获取所有的拦截器,并依次拦截
* 当进入拦截器链中的某个拦截器,并执行preHandle方法后
* 1.当preHandle方法返回false时,从当前拦截器往回执行所有拦截器的afterCompletion方法,再退出拦截器链。
* 也就是说,请求不继续往下传了,直接沿着来的链往回跑。
* 2.当preHandle方法全为true时,执行下一个拦截器,直到所有拦截器执行完。再运行被拦截的Controller。
* 然后进入拦截器链,运行所有拦截器的postHandle方法,完后从最后一个拦截器往回执行所有拦截器的afterCompletion方法.
* @author lenovo
*
*/
public class SessionInterceptor implements HandlerInterceptor {
@Override
public boolean preHandle(HttpServletRequest request,
HttpServletResponse response, Object handler) throws Exception {
HttpSession session = request.getSession();
//从session中拿到登陆信息
Object name = session.getAttribute("name");
//判断拿到的登陆信息是空的话就没登陆
if(name==null){
//重定向到登录页面
response.sendRedirect("login.do");
return false;
}
//return true 就接着往下走 return false就不往下走了
return true;
}
@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.xml中配置拦截器
<!-- 配置拦截器 -->
<mvc:interceptors>
<mvc:interceptor>
<!-- 要拦截的路径:全部拦截 -->
<mvc:mapping path="/**"/>
<!-- <mvc:exclude-mapping>不拦截的路径 -->
<mvc:exclude-mapping path="/hello/login.do"/>
<mvc:exclude-mapping path="/hello/save.do"/>
<mvc:exclude-mapping path="/hello/check.do"/>
<!-- 用哪个拦截器 -->
<bean class="cn.interceptor.SessionInterceptor"/>
</mvc:interceptor>
</mvc:interceptors>
完成!