Введение
Перехватчик в Java — это объект, который динамически перехватывает вызовы Action.Он предоставляет механизм, который позволяет разработчикам выполнять часть кода до и после выполнения Action, а также может предотвращать выполнение Action до его выполнения. извлекать повторно используемые части кода в Actions. В АОП перехватчики используются для перехвата метода или поля до обращения к ним, а затем добавления некоторых операций до или после них.
код перехватчика
Java-часть
public class HandlerInterceptorAdapter implements HandlerInterceptor {
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler)
throws Exception{
}
public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView)
throws Exception{
}
public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex)
throws Exception{
}
}
раздел конфигурации spring-MVC
<!--配置拦截器, 多个拦截器,顺序执行 -->
<mvc:interceptors>
<mvc:interceptor>
<!-- 匹配的是url路径, 如果不配置或/**,将拦截所有的Controller -->
<mvc:mapping path="/ps/**" />
<!--<mvc:mapping path="/user/**" />-->
<!--<mvc:mapping path="/test/**" />-->
<bean class="com.weixin.InterceptorAdapter.HandlerInterceptorAdapter"></bean>
</mvc:interceptor>
<!-- 当设置多个拦截器时,先按顺序调用preHandle方法,然后逆序调用每个拦截器的postHandle和afterCompletion方法 -->
</mvc:interceptors>
Использование перехватчика
Исходный код интерфейса
//继承spring的拦截接口,实现以下三个方法
public interface HandlerInterceptor {
// 在业务处理器处理请求之前被调用
boolean preHandle(HttpServletRequest var1, HttpServletResponse var2, Object var3) throws Exception;
// 在业务处理器处理请求完成之后,生成视图之前执行
void postHandle(HttpServletRequest var1, HttpServletResponse var2, Object var3, ModelAndView var4) throws Exception;
// 在DispatcherServlet完全处理完请求之后被调用,可用于清理资源,日志打印
void afterCompletion(HttpServletRequest var1, HttpServletResponse var2, Object var3, Exception var4) throws Exception;
}
Подробное объяснение preHandle
Метод preHandle имеет три параметра: объект HttpServletRequest HttpServletResponse. Проходящие параметры:
HttpServletRequest 控制程序在业务处理器前的请求参数
HttpServletResponse 控制程序在经过处理器后的返回参数
Object 被拦截的请求Action的实体
возвращаемое значение:
true表示继续流程
false表示流程中断,不会继续调用其他的拦截器或处理器,此时我们需要通过response来产生响应
Пример:
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception{
//计算出服务器当前时间
Long timeNowForServer=new Date().getTime();
//获取从前端接口请求的参数
if(null!=request.getParameter("token")){
//因为前端请求做了加密,所以这里需要对应的解密过程
String token=EncryptUtil.aesDecrypt(request.getParameter("token"),"0000000000000000");
if(null!=token) {
Long timeNowForClient = Long.parseLong(token);
//如果请求接口在五秒内
Long timeMinus = timeNowForServer - timeNowForClient;
if (-50000 <= timeMinus && timeMinus <= 50000) {
//继续接口流程
return true;
} else {
//返回相应的HTTP状态码,达到拦截的效果
//response.sendError(http状态码,页面显示的拦截原因);
response.sendError(405, "Parameters illegal");
//打回这次操作,返回相应的response
return false;
}
}else{
response.sendError(405, "Parameters illegal");
return false;
}
//或者请求地址中含有getUserInfo就放开对这个请求的拦截,等于白名单的效果
}else if(request.getRequestURI().indexOf("getUserInfo")>0){
return true;
}else{
//跳转到其他页面
response.sendRedirect(request.getContextPath() + "/Login1.html");
return false;
}
}
Код состояния может относиться кПолный список кодов состояния HTTP