文章目录
一、拦截器
1.1 拦截器的配置
*1.SpringMVC中的拦截器用于拦截控制器方法的执行
*2.SpringMVC中的拦截器需要实现HandlerInterceptor
*3.SpringMVC的拦截器必须在SpringMVC的配置文件中进行配置:
以下两种配置方式都是对DispatcherServlet所处理的所有的请求进行拦截:
<!--第一种配置拦截器方式-->
<mvc:interceptors>
<bean class="cn.hncj.interceptors.FirstInterceptor"></bean>
</mvc:interceptors>
<!--第二种配置拦截器,需要在FirstInterceptor类中添加注解@Component-->
<mvc:interceptors>
<ref bean="firstInterceptor"></ref>
</mvc:interceptors>
以下配置方式可以通过ref或bean标签设置拦截器,通过mvc:mapping设置需要拦截的请求,通过 mvc:exclude-mapping设置需要排除的请求,即不需要拦截的请求:
<!--配置拦截器-->
<mvc:interceptors>
<mvc:interceptor>
<!--mapping表示设置要拦截的路径-->
<mvc:mapping path="/**"></mvc:mapping>
<!--exclude-mapping表示要排除的请求映射排除-->
<mvc:exclude-mapping path="/testRequestEntity"></mvc:exclude-mapping>
<!--指定拦截器-->
<ref bean="firstInterceptor"></ref>
</mvc:interceptor>
</mvc:interceptors>
1.2、拦截器的三个抽象方法
*1.preHandle:控制器方法执行之前执行preHandle(),其boolean类型的返回值表示 是否拦截或放行,
返回true为放行,即调用控制器方法;返回false表示拦截,即不调用控制器方法.
*2.postHandle:控制器方法执行之后执行postHandle()
*3.afterComplation:处理完视图和模型数据,渲染视图完毕之后执行afterComplation()
1.3、多个拦截器的执行顺序
*1.若每个拦截器的preHandle()都返回true,此时多个拦截器的执行顺序和拦截器在SpringMVC的配置文件的配置顺序有关:
preHandle()会按照配置的顺序执行,而postHandle()和afterComplation()会按照配置的反序执行
*2.若某个拦截器的preHandle()返回了false,preHandle()返回false和它之前的拦截器的preHandle()都会执行,
postHandle()都不执行,返回false的拦截器之前的拦截器的afterComplation()会执行
二、异常处理器
2.1、基于配置的异常处理
*1. SpringMVC提供了一个处理控制器方法执行过程中所出现的异常的接口:HandlerExceptionResolver
*2. HandlerExceptionResolver接口的实现类有:
DefaultHandlerExceptionResolver 和 SimpleMappingExceptionResolver
*3. SpringMVC提供了自定义的异常处理器SimpleMappingExceptionResolver,使用方式如下:
在springMVC.xml中配置如下:
<!--配置异常处理-->
<bean class="org.springframework.web.servlet.handler.SimpleMappingExceptionResolver">
<property name="exceptionMappings">
<props>
<!--properties的键表示处理器方法执行过程中出现的异常
properties的值表示若出现指定异常时,设置一个新的视图名称,跳转到指定页面 -->
<prop key="java.lang.ArithmeticException">error</prop>
</props>
</property>
<!--exceptionAttribute属性设置一个属性名,将出现的异常信息在请求域中进行共享-->
<property name="exceptionAttribute" value="ex"></property>
</bean>
控制器方法:
@RequestMapping("/testExceptionHandler")
public String testExceptionHandler(){
System.out.println(1/0);
return "success";
}
error.html:
<body>
错了!!
<p th:text="${ex}"></p>
</body>
2.2、基于注解的异常处理
在controller包下新建一个控制器:
package cn.hncj.controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.ControllerAdvice;
import org.springframework.web.bind.annotation.ExceptionHandler;
/**
* Created on 2022/4/5.
*
* @author Hou chaof
*/
@ControllerAdvice
public class ExceptionController {
@ExceptionHandler(value = {ArithmeticException.class, NullPointerException.class})
public String tsetException(Exception ex, Model model) {
model.addAttribute("ex",ex);
return "error";
}
}
TestController控制器不变:
@RequestMapping("/testExceptionHandler")
public String testExceptionHandler(){
System.out.println(1/0);
return "success";
}
error.html:
<body>
错了!!
<p th:text="${ex}"></p>
</body>
结果如下: