基本概述
拦截器Interceptor
拦截器类似于JavaWeb部分学过Filter过滤器,在请求到达目标方法之前,对请求拦截,可以进行身份验证、日志等
拦截器与Filter的区别
https://blog.youkuaiyun.com/zxd1435513775/article/details/80556034
如何实现一个拦截器
1.自定义类实现 HandlerInterceptor接口的方法
public class LoginInterceptor implements HandlerInterceptor{
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler)
throws Exception {
}
@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 {
}
}
preHandle():该方法在目标方法之前被调用, 若返回值为true,则继续调用后续的拦截器和目标方法,若返回值为false,则不会再调用后续的拦截器和目标方法可以考虑做权限,日志或者事务等
postHandle():调用目标方法之后,但渲染视图之前被调用 可以对请求域中的属性或者视图做出修改!
afterCompletion():渲染视图之后被调用, 可以在该方法中进行一些释放资源的操作
2.在springmvc配置文件中配置相对应的拦截器(分为拦截所有请求和自定义拦截路径)
1、拦截所有请求
<mvc:interceptors>
<!--配置自定义拦截器 ,所有的路径都拦截 -->
<bean class="com.xz.interceptor.LoginInterceptor"></bean>
</mvc:interceptors>
2、自定义拦截请求(配置路径时不要带项目名,在服务器端解析)
<mvc:interceptors>
<mvc:interceptor>
<!--在服务器进行解析,不能加上项目名-->
<!--拦截指定路径或请求-->
<mvc:mapping path="/user/**"/>
<mvc:mapping path="/admin/**"/>
<!--不拦截指定路径或请求-->
<mvc:exclude-mapping path="/user"/>
<mvc:exclude-mapping path="/userlogin"/>
<mvc:exclude-mapping path="/admin/login"/>
<mvc:exclude-mapping path="/admin/user/login"/>
<!--指定拦截器-->
<bean class="com.xz.interceptor.LoginInterceptor"></bean>
</mvc:interceptor>
</mvc:interceptors>
SpringMVC 拦截器不拦截静态资源的三种处理方式:https://blog.youkuaiyun.com/qq_37677519/article/details/78164227
登录拦截器案例的实现
1、自定义类实现 HandlerInterceptor接口
public class LoginInterceptor implements HandlerInterceptor{
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler)
throws Exception {
//在拦截点执行拦截,如果返回true则不执行拦截点后的操作(拦截成功)
//返回false则不进行拦截
HttpSession session = request.getSession();
if(session.getAttribute("USER_NAME")!=null) {
// 登录成功不拦截
return true;
}else {
// 拦截后进入登录页面
response.sendRedirect(request.getContextPath()+"/user");
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 {
//执行完毕,返回前拦截
}
}
2.在springmvc配置文件中配置相对应的拦截器
<!--自定义拦截器-->
<mvc:interceptors>
<mvc:interceptor>
<!--在服务器进行解析,不能加上项目名-->
<!--拦截指定路径或请求-->
<mvc:mapping path="/user/**"/>
<mvc:mapping path="/admin/**"/>
<!--不拦截指定路径或请求-->
<mvc:exclude-mapping path="/user"/>
<mvc:exclude-mapping path="/userlogin"/>
<mvc:exclude-mapping path="/admin/login"/>
<mvc:exclude-mapping path="/admin/user/login"/>
<!--指定拦截器-->
<bean class="com.xz.interceptor.LoginInterceptor"></bean>
</mvc:interceptor>
</mvc:interceptors>
多拦截器的执行顺序
多拦截器情况下,拦截器的执行顺序是由配置在springmvc.xml文件中的拦截器的顺序决定
<mvc:interceptors>
<mvc:interceptor>
<mvc:mapping path="/user/**"/>
<bean class="com.xz.interceptor.LoginInterceptor1"></bean>
</mvc:interceptor>
<mvc:interceptor>
<mvc:mapping path="/admin/**"/>
<bean class="com.xz.interceptor.LoginInterceptor2"></bean>
</mvc:interceptor>
</mvc:interceptors>
源码解析