spring MVC 文件上传的MaxUploadSizeExceededException异常处理

spring MVC上传文件使用了common.fileupload组件,该组件上传文件的时候有个文件大小的限制,在超出这个限制之后.会抛出MaxUploadSizeExceededException异常.

该异常是spring检查上传文件的信息的时候抛出的,此时还没进入Controller内解析文件的方法中.


网上查到的方法是:

1 使用org.springframework.web.servlet.handler.SimpleMappingExceptionResolver,如:

  1. <bean id="exceptionResolver" class="org.springframework.web.servlet.handler.SimpleMappingExceptionResolver">  
  2.     <property name="exceptionMappings">  
  3.    <props>  
  4.         <prop key="org.springframework.web.multipart.MaxUploadSizeExceededException">error/maxUploadExceeded</prop>  
  5.    </props>   
  6. </property>  
个人更赞成这种方式,因为multipartResolver通常是全局使用的,指定的maxUploadSize通常也是全局的,这里应该配置一个全局异常处理来响应。

自己实现.HandlerExceptionResolver类,如
  1. public class MyHandlerExceptionResolver implements HandlerExceptionResolver {  
  2.     private Log log = LogFactory.getLog(getClass());  
  3.     public ModelAndView resolveException(HttpServletRequest request,  
  4.             HttpServletResponse response, Object handler, Exception ex) {  
  5.         log.warn("Handle exception: " + ex.getClass().getName());  
  6.                 
  7.         Map model = new HashMap();  
  8.         model.put("ex", ex.getClass().getSimpleName());  
  9.         model.put("error", ex.getMessage());  
  10.         return new ModelAndView("error", model);  
  11.     }  

另定义<bean class="MyHandlerExceptionResolver "/>


这两种方法的侵入性真的太大了,查看源代码org.springframework.web.multipart.commons.CommonsMultipartResolver 127行

  1. if (this.resolveLazily) {  
  2.             return new DefaultMultipartHttpServletRequest(request) {  
  3.                 @Override  
  4.                 protected void initializeMultipart() {  
  5.                     MultipartParsingResult parsingResult = parseRequest(request);  
  6.                     setMultipartFiles(parsingResult.getMultipartFiles());  
  7.                     setMultipartParameters(parsingResult.getMultipartParameters());  
  8.                 }  
  9.             };  
  10.         }  

有个resolveLazily属性,一个类似懒加载的属性.可以定义该属性.让解析文件的时候再抛异常,然后Controller中定义异常处理的方法

  1. <bean id="multipartResolver"  
  2.         class="org.springframework.web.multipart.commons.CommonsMultipartResolver"  
  3.         p:defaultEncoding="utf-8" >  
  4.       <property name="resolveLazily" value="true"/>  
  5.       <property name="maxUploadSize" value="1024" />  
  6.     </bean>  
定义异常处理的方法

  1. @ExceptionHandler(Exception.class)       
  2.     public String handleException(Exception ex,HttpServletRequest request) {     
  3.         if(ex instanceof org.springframework.web.multipart.MaxUploadSizeExceededException){  
  4.             request.setAttribute("error""文件超过长度");  
  5.         }  
  6.         return "要转向的页面,可以自由定义或者是原页面.";  
  7.     }  

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Spring MVC提供了一个很好的机制来处理应用程序中的异常——统一异常处理。通过使用统一异常处理,您可以将应用程序中发生的所有异常都交给一个中央异常处理器来处理,从而简化了应用程序的错误处理流程,并提高了代码的可维护性。 实现统一异常处理的步骤如下: 1.创建一个异常处理类,该类必须实现`HandlerExceptionResolver`接口。 ```java public class ExceptionResolver implements HandlerExceptionResolver { @Override public ModelAndView resolveException(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) { ModelAndView mav = new ModelAndView(); mav.addObject("exception", ex); mav.setViewName("error"); return mav; } } ``` 2.在Spring配置文件中配置异常处理器。 ```xml <bean class="com.example.ExceptionResolver"/> ``` 3.在控制器中抛出异常。 ```java @RequestMapping(value = "/test") public String test() throws Exception { throw new Exception("测试异常处理"); } ``` 4.创建一个错误页面,用于显示异常信息。 ```html <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Error</title> </head> <body> <h1>Error</h1> <p>${exception.message}</p> </body> </html> ``` 当您运行应用程序并访问`/test`URL时,应用程序将抛出一个异常,并且异常处理器将捕获该异常并将其转发到错误页面,以便您可以查看异常的详细信息。 需要注意的是,统一异常处理只适用于在控制器中发生的异常。如果您的应用程序中的其他组件(如拦截器、过滤器等)抛出了异常,您需要手动处理这些异常。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值