大家好,我是【1+1=王】, 热爱java的计算机(人工智能)渣硕研究生在读。
如果你也对java、人工智能等技术感兴趣,欢迎关注,抱团交流进大厂!!!
Good better best, never let it rest, until good is better, and better best.
近期会重新温习一下SSM的相关知识,相应的博客会更新至专栏【SSM框架】中,欢迎大家关注!
SSM专栏:https://blog.csdn.net/weixin_43598687/category_11652306.html
Spring MVC 的拦截器类似于Servlet 开发中的过滤器Filter,用于对处理器进行预处理和后处理。
过滤器Filter | 拦截器Interceptor | |
---|---|---|
使用范围 | servlet 规范中的一部分,任何Java Web 工程都可以使用 | SpringMVC 框架自己的,只有使用了SpringMVC 框架的工程才能用 |
拦截过滤范围 | 在url-pattern 中配置了/*之后,可以对所有要访问的资源拦截 | 在mvc:mappingpath=“”/中配置了/**之后,也可以多所有资源进行拦截,但是可以通过mvc:exclude-mappingpath=“”/标签排除不需要拦截的资源 |
HandlerInterceptor接口为org.springframework.web.servlet.HandlerInterceptor
public class MyInterceptor implements HandlerInterceptor {
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
System.out.println("preHandle执行了.......");
return true;
}
@Override
public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
System.out.println("postHandle执行了.......");
}
@Override
public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
System.out.println("afterCompletion执行了.......");
}
}
实现HandlerInterceptor接口后可以重写三个方法:
@Controller
public class InterceptorController {
@RequestMapping("/inter")
@ResponseBody
public ModelAndView interceptorTest(){
System.out.println("Controller中的业务方法开始执行");
ModelAndView modelAndView = new ModelAndView("success");
modelAndView.addObject("msg","wybegin");
return modelAndView;
}
}
<!--mvc的注解驱动-->
<mvc:annotation-driven conversion-service="conversionService"/>
<!--拦截器-->
<mvc:interceptors>
<mvc:interceptor>
<mvc:mapping path="/**"/>
<bean class="com.wang.interceptor.MyInterceptor"/>
</mvc:interceptor>
</mvc:interceptors>
SpringMVC中的异常处理思路是:当Dao、Service、Controller出现异常时都通过throws Exception向上抛出,最后由SpringMVC前端控制器交由异常处理器进行异常处理。
SpringMVC提供了两种异常处理的方式:自带的简单异常处理处、自定义异常处理器。
这是SpringMVC已经定义好了的异常处理器,在使用时可以根据项目情况进行相应异常与视图的映射配置。
<!-- 简单异常处理器 -->
<bean class="org.springframework.web.servlet.handler.SimpleMappingExceptionResolver">
<property name="defaultErrorView" value="default_error"/>
<property name="exceptionMappings">
<map>
<entry key="java.lang.NullPointerException" value="null_error"/>
<entry key="java.lang.NumberFormatException" value="format_error"/>
</map>
</property>
</bean>
当发生的异常没有被配置时,就会跳转到默认的页面:
public class MyExceptionResolver implements HandlerExceptionResolver {
@Override
public ModelAndView resolveException(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object o, Exception e) {
ModelAndView mav = new ModelAndView();
// 发生异常时跳转的页面
mav.setViewName("default_error");
return mav;
}
}
<!-- 自定义异常处理器 -->
<bean id="exceptionResolver" class="com.wang.exception.MyExceptionResolver"/>
SSM专栏:https://blog.csdn.net/weixin_43598687/category_11652306.html
版权说明 : 本文为转载文章, 版权归原作者所有 版权申明
原文链接 : https://blog.csdn.net/weixin_43598687/article/details/123552648
内容来源于网络,如有侵权,请联系作者删除!