WebWork文件上傳實(shí)現(xiàn)淺析
Webwork文件上傳看了很多的文章收獲不少,目前比較簡單的方式是通過webwork提供的FileUploadInterceptor來實(shí)現(xiàn)Webwork文件上傳,這個(gè)攔截器在使用的時(shí)候是非常方便的,通過這個(gè)攔截器可以自動(dòng)獲得上傳文件的文件名、文件類型、文件三個(gè)部分。然后用戶可以再進(jìn)行后續(xù)的處理,包括將文件信息存入數(shù)據(jù)庫、移動(dòng)文件到制定的文件夾等。
對于這個(gè)攔截器的工作原理大致是這樣的,用戶執(zhí)行Action的時(shí)候,攔截器構(gòu)造request:
java 代碼
- HttpServletRequest request = (HttpServletRequest)
- ac.get(ServletActionContext.HTTP_REQUEST);
然后判斷request是否是MultiPartRequestWrapper的一個(gè)實(shí)例,接下來初始化MultiPartRequestWrapper:
java 代碼
- MultiPartRequestWrapper multiWrapper =
- (MultiPartRequestWrapper) request;
這里就通過判斷用戶在webwork.properties中定義Webwork文件上傳類型來構(gòu)造MultiPartRequestWrapper,
java 代碼
- String parser = Configuration.getString
- (WebWorkConstants.WEBWORK_MULTIPART_PARSER);
- // If it's not set, use Jakarta
- if (parser.equals("")) {
- log.warn("Property webwork.multipart.parser not set." +
- " Using com.opensymphony.webwork.dispatcher.
- multipart.JakartaMultiPartRequest");
- parser = "com.opensymphony.webwork.dispatcher.
- multipart.JakartaMultiPartRequest";
- }
- // legacy support for old style property values
- else if (parser.equals("pell")) {
- parser = "com.opensymphony.webwork.dispatcher.
- multipart.PellMultiPartRequest";
- } else if (parser.equals("cos")) {
- parser = "com.opensymphony.webwork.dispatcher.
- multipart.CosMultiPartRequest";
- } else if (parser.equals("jakarta")) {
- parser = "com.opensymphony.webwork.dispatcher.
- multipart.JakartaMultiPartRequest";
- }
假設(shè)用戶定義了jakarta,這時(shí)候就通過JakartaMultiPartRequestMonitor來實(shí)現(xiàn)Webwork文件上傳(通過common-fileupload),同時(shí)獲得文件的名稱和類型等信息。
對于文件上傳進(jìn)度條,網(wǎng)上提供了一種給予servlet的解決辦法,這種方式可以很方便的使用在Struts模式下的mvc架構(gòu)的程序中,其中用到的類包可以在http://www.telio.be/blog/wp-content/uploads/2006/01/上找到,這種方式的實(shí)質(zhì)是用到了dwr的回調(diào)方式。servlet的上傳方式是通過下面的方式實(shí)現(xiàn)的:
java 代碼
- ServletFileUpload upload =
- new ServletFileUpload(factory);
- upload.parseRequest(servletRequest);
而進(jìn)度條是通過實(shí)現(xiàn)一個(gè)factory,來實(shí)現(xiàn)上傳狀態(tài)的回調(diào)。
webwork的攔截器實(shí)際已經(jīng)將上傳文件到臨時(shí)目錄封裝在內(nèi)部的類中,這樣我們就無法構(gòu)造factory來實(shí)現(xiàn)進(jìn)度條的監(jiān)控,給予以上的考慮,想了一個(gè)比較笨的辦法,將MultiPartRequestWrapper修改一下,增加一個(gè)新的屬性定義:
java 代碼
- else if (parser.equals("monitor"))
- {
- parser = "com.opensymphony.webwork.
- dispatcher.multipart.JakartaMultiPartRequestMonitor";
- }
這樣用戶可以在webwork.properties中設(shè)置上傳的模式為monitor,然后自己實(shí)現(xiàn)一個(gè)JakartaMultiPartRequestMonitor,在這個(gè)class中,將原有的factory實(shí)現(xiàn)方法通過帶進(jìn)度條的方式來實(shí)現(xiàn),這樣就能監(jiān)控到servlet上傳的進(jìn)度?;镜膶?shí)現(xiàn)思路就是這樣的。下面將幾個(gè)配置過程整理一下:
1、將修改的兩個(gè)類添加到webwork2.2.x。jar中:MultiPartRequestWrapper。class和JakartaMultiPartRequestMonitor.class
2、修改webwork.webwork.properties:webwork.multipart.parser=monitor
3、將剛才下載的be.telio.mediastore.ui.upload的代碼加入
4、修改dwr.xml文件,添加下面的代碼:
xml 代碼
- <create creator="new" javascript="UploadMonitor">
- name="class" value="
- be.telio.mediastore.ui.upload.UploadMonitor"/>
- create>
- <convert converter="bean" match="
- be.telio.mediastore.ui.upload.UploadInfo"/>
5、將下載的包中的resource文件夾拷貝到web目錄下
6、建立一個(gè)文件上傳action
7、建立Webwork文件上傳頁面,添加幾個(gè)js,同時(shí)在form中添加startProgress():
- <script src='/ugc/resources/js/upload.js'> </script>
- <script src='/ugc/dwr/interface/UploadMonitor.js'>
- </script>
- <script src='/ugc/dwr/engine.js'>
- </script>
- <script src='/ugc/dwr/util.js'>
- </script>
- <ww:form action="doUpload" method="POST" enctype="
- multipart/form-data" onsubmit="startProgress()">
這樣WebWork文件上傳進(jìn)度條就可以實(shí)現(xiàn)了
【編輯推薦】