SpringMvc 浅析 之 错误处理

本文介绍Spring MVC中的多种异常处理方式,包括使用@ExceptionHandler注解、SimpleMappingExceptionResolver配置及自定义异常处理类,并探讨如何针对404错误进行特定处理。

@ExceptionHandler

在一个controller中定义一个方法,用@ExceptionHandler注解标注。(优先级最高)

    @ExceptionHandler
    public ModelAndView handlerException(Exception ex) {
        Map<String, String> model = new HashMap<String, String>();
        model.put("error", ex.toString());
        return new ModelAndView("/error/error", model);
    }

SimpleMappingExceptionResolver

xml配置

<bean class="org.springframework.web.servlet.handler.SimpleMappingExceptionResolver">  
    <!-- 定义异常处理页面用来获取异常信息的变量名,默认名为exception -->  
    <!--<property name="exceptionAttribute" value="ex"></property>-->  
    <property name="exceptionMappings">  
        <props>  
            <prop key="java.lang.Throwable">error/error</prop>  
        </props>  
    </property>  
</bean> 

这里的exceptionMappings是支持自定义exception的。

自定义异常处理(优先级次之)

继承AbstractHandlerExceptionResolver即可。

public class HandlerError extends AbstractHandlerExceptionResolver {

    @Override
    protected ModelAndView doResolveException(HttpServletRequest arg0, HttpServletResponse arg1, Object arg2,
            Exception arg3) {
        ModelAndView mv = new ModelAndView("/error/error");
        mv.addObject("error", arg3.getMessage());
        return mv;
    }
}

xml配置

    <bean id="handlerError"
        class="com.yvan.error.HandlerError"> 
    </bean> 

实际开发程序出现异常错误,上面的几种方式都可以跳转到错误页,但是如果是404的情况,我们需要处理。

  • web.xml配置
<error-page>
        <error-code>404</error-code>
        <location>/WEB-INF/Views/share/404.jsp</location>
    </error-page>

这样设置之后要是访问web项目404都会跳转到404.jsp

  • 继承DispatcherServlet重写noHandlerFound
public class DefineDispatcherServlet  extends DispatcherServlet{

    /**
     * 
     */
    private static final long serialVersionUID = 1L;

    @Override
    protected void noHandlerFound(HttpServletRequest arg0, HttpServletResponse arg1) throws Exception {
        // TODO Auto-generated method stub
        arg1.sendRedirect("http://www.youkuaiyun.com/");
    }

}

这里是重定向了外部网站。

这里说明一下:配置了web.xml中的404,无论…./notFound/404.do或者是…./notFound/404,只要找不到都会跳转到404.jsp,但是利用继承DispatcherServlet重写noHandlerFound,只有访问…./notFound/404.do的时候才会进入noHandlerFound方法。

补充:
在自定义异常处理继承AbstractHandlerExceptionResolver来处理错误的,如果想跳转到外站,如下:

public class HandlerError extends AbstractHandlerExceptionResolver {

    @Override
    protected ModelAndView doResolveException(HttpServletRequest arg0, HttpServletResponse arg1, Object arg2,
            Exception arg3) {
        return new ModelAndView(new RedirectView("http://www.youkuaiyun.com/"));
    }
}
根据原作 https://pan.quark.cn/s/0ed355622f0f 的源码改编 野火IM解决方案 野火IM是专业级即时通讯和实时音视频整体解决方案,由北京野火无限网络科技有限公司维护和支持。 主要特性有:私有部署安全可靠,性能强大,功能齐全,全平台支持,开源率高,部署运维简单,二次开发友好,方便与第三方系统对接或者嵌入现有系统中。 详细情况请参考在线文档。 主要包括一下项目: 野火IM Vue Electron Demo,演示如何将野火IM的能力集成到Vue Electron项目。 前置说明 本项目所使用的是需要付费的,价格请参考费用详情 支持试用,具体请看试用说明 本项目默认只能连接到官方服务,购买或申请试用之后,替换,即可连到自行部署的服务 分支说明 :基于开发,是未来的开发重心 :基于开发,进入维护模式,不再开发新功能,鉴于已经终止支持且不再维护,建议客户升级到版本 环境依赖 mac系统 最新版本的Xcode nodejs v18.19.0 npm v10.2.3 python 2.7.x git npm install -g node-gyp@8.3.0 windows系统 nodejs v18.19.0 python 2.7.x git npm 6.14.15 npm install --global --vs2019 --production windows-build-tools 本步安装windows开发环境的安装内容较多,如果网络情况不好可能需要等较长时间,选择早上网络较好时安装是个好的选择 或参考手动安装 windows-build-tools进行安装 npm install -g node-gyp@8.3.0 linux系统 nodej...
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值