2021最新版SpringCloud高频面试题分享
854
2022-05-30
1 -的配置
SpringMVC中的-用于拦截控制器方法的执行
SpringMVC中的-需要实现HandlerInterceptor
SpringMVC的-必须在SpringMVC的配置文件中进行配置
2 -的三个抽象方法
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()会执行
@Component public class FirstInterceptor implements HandlerInterceptor { @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { System.out.println("FirstInterceptor-->preHandle"); return true; // 是否进行放行,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"); } }
异常处理器
1 基于配置的异常处理
SpringMVC提供了一个处理控制器方法执行过程中所出现的异常的接口:HandlerExceptionResolver
HandlerExceptionResolver接口的实现类有:DefaultHandlerExceptionResolver和
SimpleMappingExceptionResolver
SpringMVC提供了自定义的异常处理器SimpleMappingExceptionResolver
2 基于注解的异常处理
SpringMVC提供了一个处理控制器方法执行过程中所出现的异常的接口:HandlerExceptionResolver
HandlerExceptionResolver接口的实现类有:DefaultHandlerExceptionResolver和SimpleMappingExceptionResolver
2.1 SpringMVC提供了自定义的异常处理器SimpleMappingExceptionResolver
2.2 基于注解的异常处理
//@ControllerAdvice将当前类标识为异常处理的组件 @ControllerAdvice public class ExceptionController { //@ExceptionHandler用于设置所标识方法处理的异常 @ExceptionHandler(value = {ArithmeticException.class, NullPointerException.class}) //ex表示当前请求处理中出现的异常对象 public String testException(Exception ex, Model model){ model.addAttribute("ex", ex); // 默认放在请求域里面 return "error"; } }
index
success error
@Controller public class TestController { @RequestMapping("/**/testInterceptor") // ANT风格,/**/多层 public String testInterceptor(){ return "success"; } @RequestMapping("/testExceptionHandler") public String testExceptionHandler(){ System.out.println(1/0); return "success"; } }
Java MVC Spring
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。