Spring MVC使用拦截器对请求进行拦截处理,用户可以自定义拦截器来实现特定的功能,自定义的拦截器必须实现HandlerInterceptor接口
preHandle():这个方法在业务处理器处理请求之前被调用,在该方法中对用户请求 request 进行处理。如果程序员决定该拦截器对请求进行拦截处理后还要调用其他的拦截器,或者是业务处理器去进行处理,则返回true;如果程序员决定不需要再调用其他的组件去处理请求,则返回false。
postHandle():这个方法在业务处理器处理完请求后,但是DispatcherServlet 向客户端返回响应前被调用,在该方法中对用户请求request进行处理。
afterCompletion():这个方法在 DispatcherServlet 完全处理完请求后被调用,可以在该方法中进行一些资源清理的操作。
xml代码:
<mvc:interceptors>
<!-- 使用bean定义一个Interceptor,直接定义在mvc:interceptors根下面的Interceptor将拦截所有的请求 -->
<bean class="org.springframework.web.servlet.i18n.LocaleChangeInterceptor"></bean>
<bean id="firstInterceptor" class="com.wiwj.app.api.controller.FirstInterceptor"></bean>
<mvc:interceptor>
<mvc:mapping path="/emps"/>
<!-- 定义在mvc:interceptor下面的表示是对特定的请求才进行拦截的 -->
<bean id="secondInterceptor" class="com.wiwj.app.api.controller.SecondInterceptor"></bean>
</mvc:interceptor>
</mvc:interceptors>
java代码:
package com.wiwj.app.api.controller;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView;
public class FirstInterceptor implements HandlerInterceptor
{
/**
* 拦截器的初始方法,它在业务方法调用之前开始运行,不管return true/false,它都会打印;
* 他的作用是不是进行初始化,加载资源等需要在业务方法开始之前的准备工作。
*/
@Override
public boolean preHandle(HttpServletRequest request,HttpServletResponse response, Object handler) throws Exception
{
System.out.println("FirstInterceptor------preHandle");
return true;
}
/**
* 在业务方法之后,视图渲染之前来完成自己的工作,如果preHandle return false,它失效;
* 主要用于业务方法处理结果完成之后进行进一步的内容、业务的加强。
*/
@Override
public void postHandle(HttpServletRequest request,HttpServletResponse response, Object handler,ModelAndView modelAndView) throws Exception
{
System.out.println("FirstInterceptor------postHandle");
}
/**
* 在视图渲染之后,一切运行完成结束后开工,它主要完成资源的释放、接口、连接、IO读取等操作的关闭,
* 以及进行性能优化时,最最后的总结呈现。如果preHandle return false,它失效;
*/
@Override
public void afterCompletion(HttpServletRequest request,HttpServletResponse response, Object handler, Exception ex)throws Exception
{
System.out.println("FirstInterceptor------afterCompletion");
}
}
注解拦截器
自定义一个注解
package com.wiwj.app.api.controller;
import java.lang.annotation.ElementType;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
import java.lang.annotation.Retention;
@Target(ElementType.METHOD)
@Retention(RetentionPolicy.RUNTIME)
public @interface AccessRequired {
}
在需要拦截的方法头上添加自定义的注解
拦截器中需要做的修改:
@Override
public boolean preHandle(HttpServletRequest request,
HttpServletResponse response, Object handler) throws Exception {
if (handler instanceof HandlerMethod)
{
AccessRequired accessrequired = ((HandlerMethod) handler).getMethodAnnotation(AccessRequired.class);
//判断方法或者类有没有添加AccessRequired注解 ,如果有则拦截,没有放过
if (accessrequired == null)
{
return true;
}else{
//拦截后获取参数
String page=request.getParameter("page");
String count=request.getParameter("pcount");
System.out.println(page+count);
return false;
}
}
return true;
}