拦截器
作用:拦截控制器方法
三个阶段:
preHandle 执行控制器方法之前
postHandle 执行控制器方法之后
afterCompletion 控制执行完成之后,会返回一个modelandview对象,此方法在render(渲染之后)被调用
配置步骤:
1.创建拦截器对象
1.1 实现HandlerInterceptor接口,并重写该接口的三个默认方法
preHandle
postHandle
afterCompletion
1.2 继承HandlerInterceptorAdapter类,并重写上述的三个方法,已经弃用,不推荐
2.在ioc容器中注册拦截器对象
三种配置方式
2.1 拦截全部请求
<mvc:interceptors>
<bean class="firstInterceptor">
</mvc:interceptors>
2.2拦截全部请求
<mvc:interceptors>
<ref bean = "firstInterceptor">
</mvc:interceptors>
前提是使用注解提前将拦截器接口的实现类注册到ioc容器中
2.3拦截指定的路径
<mvc:interceptors>
<mvc:interceptor>
<mvc:mapping path="/**"/>
<mvc:exclude-mapping path="/"/>
<ref bean="firstInterceptor"></ref>
</mvc:interceptor>
</mvc:interceptors>
<mvc:mapping path="/**"/> 表示拦截“/”一下的任意级的url 如/a ,/a/a/a/a 都会被拦截
<mvc:exclude-mapping path="/"/> 配置不被拦截的url
<ref bean="firstInterceptor"></ref> 引入拦截器实现类
放行与不放行
不放行只能在发生在preHandle阶段
当preHandle的返回值是false的时候,不放行,返回值是true的时候放行
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
System.out.println("preHandle works");
return true;
}
标签:控制器,拦截器,preHandle,放行,拦截,方法 来源: https://www.cnblogs.com/new228666/p/16399056.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。