spring mvc CommonsMultipartResolver文件上傳maxUploadS

第一步:配置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>  
相關文章
相關標籤/搜索