自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

WebWork文件上傳實(shí)現(xiàn)淺析

開發(fā) 后端
本文向您介紹WebWork文件上傳的示例,通過攔截器自動(dòng)獲得上傳文件的文件名、文件類型、文件三個(gè)部分。

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 代碼

  1. HttpServletRequest request = (HttpServletRequest)   
  2. ac.get(ServletActionContext.HTTP_REQUEST);    

然后判斷request是否是MultiPartRequestWrapper的一個(gè)實(shí)例,接下來初始化MultiPartRequestWrapper:

java 代碼

  1. MultiPartRequestWrapper multiWrapper =   
  2. (MultiPartRequestWrapper) request; 

這里就通過判斷用戶在webwork.properties中定義Webwork文件上傳類型來構(gòu)造MultiPartRequestWrapper,

java 代碼

  1. String parser = Configuration.getString  
  2. (WebWorkConstants.WEBWORK_MULTIPART_PARSER);      
  3. // If it's not set, use Jakarta      
  4. if (parser.equals("")) {      
  5. log.warn("Property webwork.multipart.parser not set." +      
  6. " Using com.opensymphony.webwork.dispatcher.  
  7. multipart.JakartaMultiPartRequest");      
  8. parser = "com.opensymphony.webwork.dispatcher.  
  9. multipart.JakartaMultiPartRequest";      
  10. }      
  11. // legacy support for old style property values      
  12. else if (parser.equals("pell")) {      
  13. parser = "com.opensymphony.webwork.dispatcher.  
  14. multipart.PellMultiPartRequest";      
  15. else if (parser.equals("cos")) {      
  16. parser = "com.opensymphony.webwork.dispatcher.  
  17. multipart.CosMultiPartRequest";      
  18. else if (parser.equals("jakarta")) {      
  19. parser = "com.opensymphony.webwork.dispatcher.  
  20. multipart.JakartaMultiPartRequest";      
  21. }     

假設(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 代碼

  1. ServletFileUpload upload =   
  2. new ServletFileUpload(factory);      
  3. 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 代碼

  1. else if (parser.equals("monitor"))   
  2. {      
  3. parser = "com.opensymphony.webwork.  
  4. dispatcher.multipart.JakartaMultiPartRequestMonitor";     
  5. }   

這樣用戶可以在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 代碼

  1. <create creator="new" javascript="UploadMonitor">     
  2. name="class" value="  
  3. be.telio.mediastore.ui.upload.UploadMonitor"/>     
  4. create>     
  5. <convert converter="bean" match="  
  6. be.telio.mediastore.ui.upload.UploadInfo"/>   

5、將下載的包中的resource文件夾拷貝到web目錄下

6、建立一個(gè)文件上傳action

7、建立Webwork文件上傳頁面,添加幾個(gè)js,同時(shí)在form中添加startProgress():

  1. <script src='/ugc/resources/js/upload.js'> </script>  
  2. <script src='/ugc/dwr/interface/UploadMonitor.js'>   
  3. </script>  
  4. <script src='/ugc/dwr/engine.js'>   
  5. </script>  
  6. <script src='/ugc/dwr/util.js'>   
  7. </script>   
  8. <ww:form action="doUpload" method="POST" enctype="  
  9. multipart/form-data" onsubmit="startProgress()">  

這樣WebWork文件上傳進(jìn)度條就可以實(shí)現(xiàn)了

【編輯推薦】

  1. WebWork注入Servlet方法詳解
  2. WebWork中返回INPUT的原因
  3. WebWork如何實(shí)現(xiàn)文件上傳配置過程
  4. 通過WebWork實(shí)現(xiàn)HelloWorld
  5. WebWork與Spring+Hibernate的整合
責(zé)任編輯:冰荷 來源: javaeye
相關(guān)推薦

2009-07-08 09:29:58

WebWork

2009-07-20 13:29:13

xwork.xmlWebWork

2009-07-16 17:26:11

WebWork文件上傳

2009-07-14 14:41:33

Webwork與Spr

2009-07-16 14:58:03

WebWork安裝WebWork配置

2009-07-14 17:53:11

WebWork安裝WebWork配置

2009-07-06 17:11:38

Servlet文件上傳

2009-07-14 15:52:00

WebWork文件下載

2009-07-14 13:08:55

WebWork與Spr

2009-07-08 09:55:51

WebWork下載

2009-07-08 10:11:30

WebWork

2009-07-09 15:55:18

WebWork配置文件

2009-07-20 16:09:39

2009-07-16 15:44:40

導(dǎo)出CSV文本WebWork

2009-07-16 15:14:27

WebWork用戶登陸

2009-07-23 10:37:43

2009-07-16 14:08:14

webwork配置

2009-07-14 16:08:41

WebWork學(xué)習(xí)

2009-07-14 17:34:53

Webwork配置

2011-09-14 09:20:03

PhonegapAndroid平臺(tái)
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)