springMVC3学习(八)--全局的异常处理

本文介绍Spring MVC中如何使用SimpleMappingExceptionResolver进行异常处理,包括配置不同异常映射到不同视图及设置默认异常视图。

在springMVC的配置文件中:

  1. <bean id="exceptionResolver" class="org.springframework.web.servlet.handler.SimpleMappingExceptionResolver"> 
  2.     <property name="defaultErrorView"> 
  3.         <value>/error</value><!-- 表示当抛出异常但没有在exceptionMappings里面找到对应的异常时 返回名叫error的视图--> 
  4.     </property> 
  5.     <property name="defaultStatusCode" value="404"/><!-- 表示在发生异常时默认的HttpServletResponse的返回码,默认是404--> 
  6.     <property name="statusCodes"><!-- 定义在发生异常时视图跟返回码的对应关系 --> 
  7.         <props> 
  8.             <!-- 表示在发生NumberFormatException时返回视图number,然后这里定义发生异常时视图number对应的HttpServletResponse的返回码是500 --> 
  9.             <prop key="number">500</prop> 
  10.             <prop key="null">503</prop> 
  11.         </props> 
  12.     </property> 
  13.     <property name="exceptionMappings"> 
  14.         <props> 
  15.             <prop key="NumberFormatException">number</prop><!-- 表示当抛出NumberFormatException的时候就返回名叫number的视图--> 
  16.             <prop key="NullPointerException">null</prop> 
  17.         </props> 
  18.     </property> 
  19. </bean>  
<bean id="exceptionResolver" class="org.springframework.web.servlet.handler.SimpleMappingExceptionResolver">
    <property name="defaultErrorView">
	    <value>/error</value><!-- 表示当抛出异常但没有在exceptionMappings里面找到对应的异常时 返回名叫error的视图-->
    </property>
    <property name="defaultStatusCode" value="404"/><!-- 表示在发生异常时默认的HttpServletResponse的返回码,默认是404-->
    <property name="statusCodes"><!-- 定义在发生异常时视图跟返回码的对应关系 -->
	    <props>
	        <!-- 表示在发生NumberFormatException时返回视图number,然后这里定义发生异常时视图number对应的HttpServletResponse的返回码是500 -->
	        <prop key="number">500</prop>
	        <prop key="null">503</prop>
	    </props>
    </property>
    <property name="exceptionMappings">
  	    <props>
	        <prop key="NumberFormatException">number</prop><!-- 表示当抛出NumberFormatException的时候就返回名叫number的视图-->
	        <prop key="NullPointerException">null</prop>
	    </props>
    </property>
</bean> 

这里主要的类是SimpleMappingExceptionResolver类,和他的父类AbstractHandlerExceptionResolver类。

你也可以实现HandlerExceptionResolver接口,写一个自己的异常处理程序.

通过SimpleMappingExceptionResolver我们可以将不同的异常映射到不同的jsp页面(通过exceptionMappings属性的配置)。

同时我们也可以为所有的异常指定一个默认的异常提示页面(通过defaultErrorView属性的配置),

如果所抛出的异常在exceptionMappings中没有对应的映射,则Spring将用此默认配置显示异常信息。


Login.java测试类

  1. import java.io.File; 
  2. import org.springframework.stereotype.Controller; 
  3. import org.springframework.web.bind.annotation.RequestMapping; 
  4.  
  5. @Controller 
  6. public class Login { 
  7.     @RequestMapping("/null"
  8.     public void testNullPointerException() { 
  9.          File file = null
  10.          // 空指针异常,返回定义在SpringMVC配置文件中的null视图 
  11.          System.out.println(file.getName()); 
  12.     } 
  13.  
  14.     @RequestMapping("/number"
  15.     public void testNumberFormatException() { 
  16.          // NumberFormatException,返回定义在SpringMVC配置文件中的number视图 
  17.          Integer.parseInt("abc"); 
  18.     } 
  19.  
  20.     @RequestMapping("/default"
  21.     public void testDefaultException() { 
  22.         if (1 == 1
  23.           // 由于该异常类型在SpringMVC的配置文件中没有指定,所以就会返回默认的exception视图 
  24.           throw new RuntimeException("Error!"); 
  25.     } 
import java.io.File;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;

@Controller
public class Login {
	@RequestMapping("/null")
	public void testNullPointerException() {
	     File file = null;
	     // 空指针异常,返回定义在SpringMVC配置文件中的null视图
	     System.out.println(file.getName());
	}

	@RequestMapping("/number")
	public void testNumberFormatException() {
	     // NumberFormatException,返回定义在SpringMVC配置文件中的number视图
	     Integer.parseInt("abc");
	}

	@RequestMapping("/default")
	public void testDefaultException() {
		if (1 == 1)
		  // 由于该异常类型在SpringMVC的配置文件中没有指定,所以就会返回默认的exception视图
		  throw new RuntimeException("Error!");
	}
}

显示错误的jsp页面(已error.jsp为例)
  1. <body> 
  2.     <
  3.         Exception e = (Exception)request.getAttribute("exception"); 
  4.         out.print(e.getMessage()); 
  5.     %> 
  6. </body> 
<body>
    <%
        Exception e = (Exception)request.getAttribute("exception");
        out.print(e.getMessage());
    %>
</body>

测试URL:   http://localhost:8080/spring_exception/null

            http://localhost:8080/spring_exception/number

            http://localhost:8080/spring_exception/default

根据原作 https://pan.quark.cn/s/459657bcfd45 的源码改编 Classic-ML-Methods-Algo 引言 建立这个项目,是为了梳理和总结传统机器学习(Machine Learning)方法(methods)或者算法(algo),和各位同仁相互学习交流. 现在的深度学习本质上来自于传统的神经网络模型,很大程度上是传统机器学习的延续,同时也在不少时候需要结合传统方法来实现. 任何机器学习方法基本的流程结构都是通用的;使用的评价方法也基本通用;使用的一些数学知识也是通用的. 本文在梳理传统机器学习方法算法的同时也会顺便补充这些流程,数学上的知识以供参考. 机器学习 机器学习是人工智能(Artificial Intelligence)的一个分支,也是实现人工智能最重要的手段.区别于传统的基于规则(rule-based)的算法,机器学习可以从数据中获取知识,从而实现规定的任务[Ian Goodfellow and Yoshua Bengio and Aaron Courville的Deep Learning].这些知识可以分为四种: 总结(summarization) 预测(prediction) 估计(estimation) 假想验证(hypothesis testing) 机器学习主要关心的是预测[Varian在Big Data : New Tricks for Econometrics],预测的可以是连续性的输出变量,分类,聚类或者物品之间的有趣关联. 机器学习分类 根据数据配置(setting,是否有标签,可以是连续的也可以是离散的)和任务目标,我们可以将机器学习方法分为四种: 无监督(unsupervised) 训练数据没有给定...
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值