spring html5 拖拽上傳多文件

注:這只是一個粗略筆記。有些代碼可能沒用。後續會再更新一個可以使用的版本。不足之處,敬請見諒。

1。spring環境搭建,這裏使用的是spring3的jar,需要同時引入common-IO 和common-fileupload的jar包。

1.1spring.XXX.xml文件配置bean

<bean id="multipartResolver"
		class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
		<property name="maxUploadSize" value="${web.maxUploadSize}" />
	</bean>
value="xxxx"根據實際情況修改。

2.html表單

<form id="uploadForm" action="data/myData4PipeiUpload" method="post" enctype="multipart/form-data">
                    <div class="upload_box">
                        <div class="upload_main">
                            <div class="upload_choose">
                                <span id="fileDragArea" class="upload_drag_area">請將文件拖拽至此處上傳</span>
                                <input id="fileImage" size="30" name="fileselects[]" multiple="multiple"  type="file">
                            </div>
                            <div id="preview" class="upload_preview"></div>
                        </div>
                       
                        <div id="uploadInf" class="upload_inf"></div>
                    </div>
                    <div class="upload_box">
                        文件名稱2:
				<input  name="fileFieName" id="fileFieName"  />
                    </div>
                    <DIV class="modal-footer">
			        <BUTTON class="btn btn-primary" type="submit" id="submitBut3" data-dismiss="modal">上傳數據文件</BUTTON>
			        </DIV>
                </form>

2.1除了普通上傳的一些格式要求之外。這裏要注意多文件需要name=“XXX[]” multiple=“multiple"

 <input id="fileImage" size="30" name="fileselects[]" multiple="multiple"  type="file">

2.2這裏使用了upload.js和zxxFile.js。去配置相關參數

3.後臺代碼編寫兩種方式。

3.1

@RequestMapping(value = "/myData4PipeiUpload", method = RequestMethod.POST)
	public void handleRequest(HttpServletRequest request,   
            HttpServletResponse response) throws Exception {   
        // 轉型爲MultipartHttpRequest:   
       MultipartHttpServletRequest multipartRequest = (MultipartHttpServletRequest) request;   
      List<MultipartFile> singleFiles = multipartRequest.getFiles("fileselects[]"); 
            
        if(singleFiles!=null&&singleFiles.size()>0){
        	for(MultipartFile file: singleFiles){
		        // 獲得文件名:   
		        String filename = file.getOriginalFilename();
		        // 獲得輸入流:   
		        InputStream input = file.getInputStream();   
		        // 寫入文件   
		        // 或者:   
		        File source = new File("d:/dd/"+filename);   
		        file.transferTo(source); 
        	}
        }
    }  
注意參數的獲取要使用fileselects[]去獲取列表

3.2,直接將請求名稱寫入到@requestParam

@RequestMapping(value = "/myData4PipeiUpload", method = RequestMethod.POST)
	public void handleRequest(@RequestParam("fileselects[]") MultipartFile[] files,HttpServletRequest request,   
			HttpServletResponse response) throws Exception {   
		           
		if(files!=null&&files.length>0){
			for(MultipartFile file: files){
				// 獲得文件名:   
				String filename = file.getOriginalFilename();
				// 獲得輸入流:   
				InputStream input = file.getInputStream();   
				// 寫入文件   
				
				// 或者:   
				File source = new File("d:/dd/"+filename);   
				file.transferTo(source); 
			}
		}
	}  
這樣子就可以再進行後續的操作。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章