SpringMVC拦截器和异常处理器使用示例超详细讲解
拦截器
1、拦截器的配置
SpringMVC中的拦截器用于拦截控制器方法的执行
SpringMVC中的拦截器需要实现HandlerInterceptor
public class FirstInterceptor implements HandlerInterceptor {
//在控制器方法之前拦截
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
System.out.println("FirstInterceptor-preHandle");
return true;
}
//在控制器方法之后拦截
@Override
public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
System.out.println("FirstInterceptor-postHandle");
}
//在视图渲染之后拦截
@Override
public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
System.out.println("FirstInterceptor-afterCompletion");
}
}SpringMVC的拦截器必须在SpringMVC的配置文件中进行配置:
<!-- 配置拦截器-->
<mvc:interceptors>
<!-- 第一种 直接将拦截器类添加进来-->
<!-- <bean class="com.Interceptors.FirstInterceptor"/>-->
<!-- 第二种 先将拦截器类注入(在FirstInterceptor类添加注解@Component),然后在扫描组件添加,就可以使用-->
<!-- <ref bean="firstInterceptor"/>-->
<!-- 以上两种配置方式都是对DispatcherServlet所处理的所有的请求进行拦截,不能配置 -->
<!-- 第三种 可以对拦截路径配置-->
<mvc:interceptor>
<!-- 需要拦截的路径-->
<mvc:mapping path="/**"/>
<!-- 不拦截的路径-->
<mvc:exclude-mapping path="/"/>
<ref bean="firstInterceptor"/>
</mvc:interceptor>
</mvc:interceptors>
<!--
以上配置方式可以通过ref或bean标签设置拦截器,通过mvc:mapping设置需要拦截的请求,通过mvc:exclude-mapping设置需要排除的请求,即不需要拦截的请求
-->
2、拦截器的三个抽象方法
SpringMVC中的拦截器有三个抽象方法:
preHandle:控制器方法执行之前执行preHandle(),其boolean类型的返回值表示是否拦截或放行,返回true为放行,即调用控制器方法;返回false表示拦截,即不调用控制器方法
postHandle:控制器方法执行之后执行postHandle()
afterComplation:处理完视图和模型数据,渲染视图完毕之后执行afterComplation()
3、多个拦截器的执行顺序
a>若每个拦截器的preHandle()都返回true
此时多个拦截器的执行顺序和拦截器在SpringMVC的配置文件的配置顺序有关:
preHandle()会按照配置的顺序执行,而postHandle()和afterComplation()会按照配置的反序执行
b>若某个拦截器的preHandle()返回了false
preHandle()返回false和它之前的拦截器的preHandle()都会执行,postHandle()都不执行,返回false的拦截器之前的拦截器的afterComplation()会执行
异常处理器
1、基于配置的异常处理
SpringMVC提供了一个处理控制器方法执行过程中所出现的异常的接口:HandlerExceptionResolver
HandlerExceptionResolver接口的实现类有:DefaultHandlerExceptionResolver和SimpleMappingExceptionResolver
SpringMVC提供了自定义的异常处理器SimpleMappingExceptionResolver,使用方式:
<bean class="org.springframework.web.servlet.handler.SimpleMappingExceptionResolver">
<property name="exceptionMappings">
<props>
<!--
properties的键表示处理器方法执行过程中出现的异常
properties的值表示若出现指定异常时,设置一个新的视图名称,跳转到指定页面
-->
<prop key="java.lang.ArithmeticException">error</prop>
</props>
</property>
<!--
exceptionAttribute属性设置一个属性名,将出现的异常信息在请求域中进行共享
设置异常信息保存在共享域中的键,默认保存在请求域,value为异常保存的键
-->
<property name="exceptionAttribute" value="exception"></property>
</bean>2、基于注解的异常处理
//@ControllerAdvice将当前类标识为异常处理的组件
@ControllerAdvice
public class ExceptionController {
//@ExceptionHandler用于设置所标识方法处理的异常
@ExceptionHandler(ArithmeticException.class)
//ex表示当前请求处理中出现的异常对象
public String handleArithmeticException(Exception exception, Model model){
model.addAttribute("exception", exception);
return "error";
}
}到此这篇关于SpringMVC拦截器和异常处理器使用示例超详细讲解的文章就介绍到这了,更多相关SpringMVC拦截器和异常处理器内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
IntelliJ IDEA进行中文汉化的详细教程(附图文讲解)
今天为大家带来的是 IntelliJ IDEA 中文汉化教程以及中文插件包下载教程,经常收到小伙伴在后台给我留言,问 IDEA 怎么进行中文汉化,因为很多小伙伴是刚入门 Java,看到 IDEA 菜单全英文有些不太适应,需要的朋友可以参考下2024-12-12
JAVA StringBuffer类与StringTokenizer类代码解析
这篇文章主要介绍了JAVA StringBuffer类与StringTokenizer类代码解析,具有一定借鉴价值,需要的朋友可以参考下2018-01-01
SpringBoot+Shiro学习之密码加密和登录失败次数限制示例
本篇文章主要介绍了SpringBoot+Shiro学习之密码加密和登录失败次数限制示例,可以限制登陆次数,有兴趣的同学可以了解一下。2017-03-03
Java如何通过反射获取Constructor、Field、Method对象
反射指的是对象的反向处理操作,根据对象取得对象的来源信息,在反射的世界里面,看重的不再是一个对象,而是对象身后的组成,下面这篇文章主要给大家介绍了关于Java如何通过反射获取Constructor、Field、Method对象的相关资料,需要的朋友可以参考下2022-06-06
Hibernate基于ThreadLocal管理Session过程解析
这篇文章主要介绍了Hibernate基于ThreadLocal管理Session过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下2020-10-10


最新评论