以前簡(jiǎn)單使用過(guò)spring的文件上傳,當時(shí)沒(méi)深入研究,以為spring只能實(shí)現單個(gè)文件的上傳,所以后來(lái)就又大致學(xué)了下commons fileupload組件。在最近的工作中,有同事提出,他在把commons fileupload組件集成到spring中時(shí)總是出錯,然后我大致看了一下,發(fā)現是spring DispatcherServlet的緣故。然后google了一下,發(fā)現sping本身就包裝了commons fileupload,并且很好用。汗顏!為自己以前無(wú)知的寫(xiě)那篇《利用Jakarta commons fileupload組件實(shí)現多文件上傳》汗顏!唉,都是自己以前不讀書(shū)不看報的結果啊,呵呵:)
一.前臺頁(yè)面
我們的目標是要實(shí)現多文件上傳,并且預先我并不知道客戶(hù)要上傳多少個(gè)文件。我們先寫(xiě)個(gè)jsp頁(yè)面吧,要實(shí)現可以動(dòng)態(tài)控制上傳多少文件,基本代碼如下:
<form method="post" action="./upload.do" enctype="multipart/form-data"><div id="uploadDiv"><input type="file" name="file1" /></div><input type="button" value="繼續上傳" onclick="javascript:btn_click();"><input type="hidden" id="fileCount" name="fileCount" value="1"><input type="submit" value="上傳" /></form>恩,要實(shí)現動(dòng)態(tài)控制上傳文件個(gè)數,我們需要使用偉大的javascript了
function btn_click()...{var fileNo=Number(document.getElementById('fileCount').value)+1;newDiv=document.createElement("div")newDiv.id="divFile"+fileNo;document.getElementById('uploadDiv').appendChild(newDiv)document.getElementById('fileCount').value=fileNo;newDiv.innerHTML="<input type='file' name='file"+fileNo+"'>";}ok,現在我們的界面如下:http://dl2.csdn.net/down4/20070710/10163733412.JPG
二.后臺實(shí)現
1. 好了,前臺我們搞定了,現在考慮一下后臺處理吧。我寫(xiě)了一個(gè)Command Bean,非常簡(jiǎn)單,如下:
public class FUploadBean ...{private byte[] file;public byte[] getFile() ...{return file;}public void setFile(byte[] file) ...{this.file = file;}}在spring Web MVC模式中,必須定義一個(gè)Command對象,將其和Form表單綁定。這個(gè)command class需要在spring上下文中進(jìn)行配置,可以作為controller的property進(jìn)行配置。呆會(huì )會(huì )在配置文件中看到相關(guān)配置。
2. 然后就是一個(gè)Controller
public class FUploadController extends SimpleFormController ...{public ModelAndView onSubmit(HttpServletRequest request,HttpServletResponse res, Object obj, BindException errors)throws Exception ...{MultipartHttpServletRequest multipartRequest = (MultipartHttpServletRequest) request;int fileCount = Integer.parseInt(request.getParameter("fileCount"));for (int i = 1; i <= fileCount; i++) ...{CommonsMultipartFile cFile = (CommonsMultipartFile) multipartRequest.getFile("file" + i);File uploadedFile = new File("E:/upload" + "/"+ cFile.getOriginalFilename());FileCopyUtils.copy(cFile.getBytes(), uploadedFile);}return null;}// 注冊一個(gè)spring的編輯器非常重要,沒(méi)有這個(gè)方法,上傳將不能進(jìn)行protected void initBinder(HttpServletRequest request,ServletRequestDataBinder binder) throws ServletException ...{binder.registerCustomEditor(byte[].class,new ByteArrayMultipartFileEditor());}}注意:必須定義initBinder方法。
三.配置文件
接下來(lái)就是配置文件了,熟悉spring的人應該很容易看懂了。
1.web.xml
<servlet><servlet-name>springStudy</servlet-name><servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class><load-on-startup>1</load-on-startup></servlet><servlet-mapping><servlet-name>springStudy</servlet-name><url-pattern>*.do</url-pattern></servlet-mapping>2.springStudy-servlet.xml
<bean id="multipartResolver"class="org.springframework.web.multipart.commons.CommonsMultipartResolver"><property name="maxUploadSize" value="50000000" /><property name="defaultEncoding" value="utf-8" /></bean><bean id="urlMapping"class="org.springframework.web.servlet.handler.SimpleUrlHandlerMapping"><property name="mappings"><props><prop key="/upload.do">uploadServlet</prop></props></property></bean><bean id="uploadServlet"class="chb.spring.study.web.FUploadController"><property name="commandClass"value="chb.spring.study.web.FUploadBean" /></bean>注:需要注意的是,在spring中要實(shí)現文件上傳,必須在spring的上下文中定義MultipartResolver,這樣spring在發(fā)現該表單請求是mutipart時(shí),就會(huì )使用spring定義的解析器去解析。這里我們使用的是
CommonsMultipartResolver,也就是會(huì )轉化為commons fileupload。CommonsMultipartResolver繼承自CommonsFileUploadSupport,而CommonsFileUploadSupport是對commons fileupload組件的包裝,所以我們可以在定義multipartResolver時(shí)設置相關(guān)參數,比如最大允許上傳文件數,字符編碼等。這里設置<property name="defaultEncoding" value="utf-8" />就是為了解決中文問(wèn)題。
Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=1684596
聯(lián)系客服