在学习拦截器之前,我们学习了过滤器以及AOP面向切面思想,
所以可以理解为拦截器是一个比过滤器更小更精准的过滤器,且作用于控制单元
过滤器针对的是你的每一个请求
过滤器一共做3件事情
拦截器主要针对的就是控制单元,我们可以理解成拦截器就是一个细化的过滤器
拦截器实现的思想就是Spring AOP
a、切点--控制单元.
b、通知--拦截器的方法
c、织成切面
执行的时机:
在进入控制单元方法之前
这个方法的返回值决定了是否继续执行控制单元的方法
即将执行控制单元中方法对象
执行的时机:
在数据处理之后进行处理
执行的时机:
在进行页面渲染的时候
package com.lin.interceptor;
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 LogInterceptor implements HandlerInterceptor {
private Logger logger = Logger.getLogger(LogInterceptor.class);
/**
* 在进入控制器方法前被调用的方法
*
* @param request 请求对象
* @param response 响应对象
* @param handler 被拦截的控制器方法
* @return true表示允许访问, false表示终止访问. 如果返回false, 需要提示客户端
* @throws Exception
*/
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
logger.error("[日志拦截: 1] - preHandle - 控制器被调用前执行 - " + handler);
return true;
}
/**
* 控制器方法调用结束, 有返回结果之后, 调用postHandle方法
*
* @param request 请求对象
* @param response 响应对象
* @param handler 控制器方法
* @param modelAndView 控制器方法返回的结果
* @throws Exception
*/
@Override
public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
logger.error("[日志拦截: 2] - postHandle - 控制器调用后执行 - " + handler);
}
/**
* 本次流程结束后会被调用的方法, 通常用于最终的异常处理
*
* @param request 请求对象
* @param response 响应对象
* @param handler 控制器方法
* @param ex 异常对象
* @throws Exception
*/
@Override
public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
logger.error("[日志拦截: 3] - afterCompletion - 流程结束 - " + handler);
}
先进后出,越后面的越先出
拦截具体和拦截所有
}
网站声明:如果转载,请联系本站管理员。否则一切后果自行承担。
加入交流群
请使用微信扫一扫!