spring mvc CommonsMultipartResolver文件上传maxUploadSize限制大小

第一步:配置sping 
Xml代码   收藏代码
  1. <bean id="multipartResolver"  
  2.           class="org.springframework.web.multipart.commons.CommonsMultipartResolver">  
  3.         <!--1024*200即200k-->  
  4.         <property name="maxUploadSize" value="204800"/>  
  5.         <!--resolveLazily属性启用是为了推迟文件解析,以便在UploadAction 中捕获文件大小异常-->  
  6.         <property name="resolveLazily" value="true"/>    
  7.     </bean>  

第二步:在上传action中自己捕获异常 
Java代码   收藏代码
  1.  @RequestMapping  
  2.     public void execute(  
  3.             @RequestParam(required = false) MultipartFile file,  
  4.             @RequestParam(value = "file_info_id", required = false) Integer fileInfoId,  
  5.             ModelMap model, HttpServletRequest request) throws Exception {  
  6.               
  7.         if (file == null || file.isEmpty()) {  
  8.             return;  
  9.         }  
  10.         byte[] bytes = file.getBytes();  
  11.             ……………………  
  12. ………………  
  13. }  
  14.   @ExceptionHandler(Exception.class)         
  15.     public ModelAndView handleException(Exception ex,HttpServletRequest request) {       
  16.          Map<Object, Object> model = new HashMap<Object, Object>();  
  17.          if (ex instanceof MaxUploadSizeExceededException){  
  18.                         model.put("errors""文件应不大于 "+  
  19.                        getFileKB(((MaxUploadSizeExceededException)ex).getMaxUploadSize()));  
  20.                      } else{  
  21.                         model.put("errors""不知错误: " + ex.getMessage());  
  22.                     }  
  23.          return new ModelAndView("/common/file/upload", (Map) model);  
  24.                   
  25.     }    
  26.       
  27.     private String getFileKB(long byteFile){  
  28.         if(byteFile==0)  
  29.            return "0KB";  
  30.         long kb=1024;  
  31.         return ""+byteFile/kb+"KB";  
  32.     }  
  33.     private String getFileMB(long byteFile){  
  34.         if(byteFile==0)  
  35.            return "0MB";  
  36.         long mb=1024*1024;  
  37.         return ""+byteFile/mb+"MB";  
  38.     }  

第三步:界面 
Html代码   收藏代码
  1. <script type="text/javascript">  
  2. $(function() {  
  3.     $('#frmupload1').submit(function() {  
  4.         if ($('#file1').val() == '') {  
  5.             alert('请选择上传导入文件!');  
  6.             $('#file1').focus();  
  7.             return false;  
  8.         }else{  
  9.             if(!isvalidatefile($('#file1').val()))  
  10.                   return false;  
  11.                   
  12.         }  
  13.     });  
  14.     $('#frmupload2').submit(function() {  
  15.         if ($('#file2').val() == '') {  
  16.             alert('请选择上传导入文件!');  
  17.             $('#file2').focus();  
  18.             return false;  
  19.         }else{  
  20.             if(!isvalidatefile($('#file2').val()))  
  21.                   return false;  
  22.                   
  23.         }  
  24.     });  
  25. });  
  26.   
  27. function isvalidatefile(obj) {  
  28.       
  29.     var extend = obj.substring(obj.lastIndexOf(".") + 1);  
  30.     //alert(extend);  
  31.     if (extend == "") {  
  32.     } else {  
  33.         if (!(extend == "xls" )) {  
  34.             alert("请上传后缀名为xls(Excel2003)或xlsx(Excel2007)的文件!");  
  35.               
  36.             return false;  
  37.         }  
  38.     }  
  39.     return true;  
  40. }  
  41. <body>  
  42. <h1>上传文件</h1>  
  43. <form action="" method="post" enctype="multipart/form-data" onsubmit="return checkSubmit();">  
  44.   
  45.     <p>请选择文件:</p>  
  46.       
  47.     <p ${not empty errors ?"style='color : red;'":""}>${errors}</p>  
  48.     <input type="file" name="file" id="file"/>&nbsp;<input type="submit" value="确定"/>  
  49. </form>  
  50. </body>  


参考来源: 
spring MVC上传文件使用了common.fileupload组件  
使用Spring MVC和注释配置来实现文件上传
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值