成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

WebWork配置筆記

開發 后端
本文向您介紹WebWork配置的一些知識,包擴webwork運行流程、Ognl工作原理和chain視圖等

在標簽方面,WebWork配置這幾個標簽是有嚴格順序的,正確順序如下:

  1. 先〈result-types〉,必須有〈result-type/〉項;       
  2. 再〈interceptors〉,必須有〈interceptor/〉項;       
  3. 接下來是〈default-interceptor-ref   name="completeStack"〉  
  4. default-interceptor-ref〉;       
  5. 然后是〈global-results〉,必須有〈result/〉項;       
  6. 然后〈global-exception-mappings〉,    
  7. 子項如〈exception-mapping result="errorPage"     
  8. exception="java.lang.Exception"/〉       
  9. ***才是〈action/〉    

***才是

  1. action name="test" 〉     
  2. 〈interceptor-ref name="exception"/ 〉     
  3. 〈interceptor-ref name="basicStack"/ 〉     
  4. 〈exception-mapping exception="com.acme.  
  5. CustomException" result="custom_error"/ 〉     
  6. 〈result name="custom_error" 〉custom_error.ftlresult 〉     
  7. 〈result name="success" type="freemarker" 〉test.ftlresult 〉     
  8. action 〉     

webwork運行流程: 

默認執行execute()方法,該方法默認返回SUCCESS;

  1. 〈Script language="JavaScript" src="/js/pagenumber.js" 〉  
  2. 〈/Script 〉     
  3. 〈script Language="JavaScript" 〉     
  4. listNumUrl("courseInfoList.action?&pageNum=" 
  5. ,${pageNum},${allPageNum});     
  6. 〈/script 〉  

Ognl工作原理:

OgnlValueStack stack=new OgnlValueStack();  

stack.push(new User())://首先將打算賦值的對象壓入棧中  

stack.setValue("name","erica");//為棧頂對象User指定的屬性名name賦值  

HttpSession是一個接口,  

Properties實現了繼承了HashTable(實現了Map接口),也就是說它保存的也是值-鍵對象,它的setProperty("name","value")實質上就是保存到HashTable里了。

默認不是ajax

  1. action name="itemPersonalInput"   
  2. class="cn.com.s520.course.ItemPersonalInputAction"〉    
  3. 〈interceptor-ref name="fileUpload"〉    
  4. 〈param name="allowedTypes"〉    
  5. application/msword,image/gif,  
  6. image/jpeg,image/pjpeg,application/x-shockwave-flash     
  7. param〉    
  8. 〈param name="maximumSize">10485760param〉    
  9. interceptor-ref〉    
  10. 〈interceptor-ref name="basicStack"/〉    
  11. 〈result name="input" type="freemarker">  
  12. /course/ItemPersonalInput.ftlresult〉    
  13. 〈result name="error" type="freemarker">  
  14. course/ItemPersonalInput.ftlresult〉    
  15. 〈result name="success" type="redirect">  
  16. /itemPersonalList.actionresult〉    
  17. action〉  

private File images;

private String imagesContentType;  

private String imagesFileName;//得到不含路徑的文件名,如test.jpg 

  1. 〈result name="success" type="stream" 〉    
  2. 〈param name="contentType">image/jpegparam 〉    
  3. 〈param name="inputName">imageStreamparam 〉    
  4. 〈param name="  
  5. contentDisposition">filename="logo.png"param 〉    
  6. 〈param name="bufferSize">4096param 〉    
  7. result> 

1,〈param name="contentType">application/x-msdownloadparam 〉


contentType設成 application/x-msdownload 就可以。這樣瀏覽器會保證彈出一個下載文件的對話框。 


2,inputName 
這個比較重要,這個名字是輸入流的名稱, 以后要steam result的實現類中為根據OGNL的表達式去查找的。 

contentDisposition 這個是下載之后,保存在用戶端的文件名稱。

3,另外一個參數:contentLength就是下載文件的大小,webwork的stream result似乎實現有問題,不能根據文件的大小動態進行設置,只能寫死。 

這個WebWork配置參數的意義是告訴瀏覽下載的文件有多大,以便瀏覽器正確的顯示進度條。如果這個功能很重要的話,可以重新寫一個RESULT來實現。

  1. 〈result>/form.jspresult>如果不指明,默認為success     
  2. action name="userReg"   
  3. class="com.opensymphony.xwork.ActionSupport" 〉    
  4. 〈result name="input">/app/userreg.ftlresult 〉    
  5. 〈/action 〉  

這里將不會出現預期的頁面,因為默認為success,不會轉向我們指定的input頁面

  1. 〈result name="no-content" type="header"〉     
  2. 〈param name="status"〉204param〉     
  3. 〈param name="headers.customHeaderA"〉Aparam〉     
  4. 〈param name="headers.customHeaderB"〉Bparam〉     
  5. result〉  

chain視圖:  

同一個包里,可設置type為chain,對應action的擴展名也可以不寫,

  1. 〈result name="error" type="chain"〉     
  2. 〈param name="actionName"〉barparam〉     
  3. result〉     

不同包里

  1. 〈result name="errorPage" type="chain" 〉     
  2. 〈param name="namespace" 〉/param 〉     
  3. 〈param name="actionName" 〉barparam 〉     
  4. result 〉     

或者設置type為redirect,重定向過去

  1. action name="index" class="  
  2. com.opensymphony.xwork.ActionSupport"〉     
  3. 〈result name="success" type="redirect"〉  
  4. /course/courseInfoList.actionresult〉     
  5. action〉   

  1. default-interceptor-ref name="defaultStack"/〉   

這里只是在你沒有設置攔截器時才用到,如果WebWork配置攔截器了,就不會調用這個了。

【編輯推薦】

  1. WebWork框架原理與應用(1)
  2. 用WebWork注冊頁面建立過程
  3. WebWork注入Servlet方法詳解
  4. WebWork中返回INPUT的原因
  5. WebWork如何實現文件上傳配置過程
責任編輯:冰荷 來源: javaeye
相關推薦

2009-07-14 16:08:41

WebWork學習

2009-07-14 17:34:53

Webwork配置

2009-07-09 15:55:18

WebWork配置文件

2009-07-14 17:53:11

WebWork安裝WebWork配置

2009-07-16 17:42:47

WebWork配置

2009-07-16 14:58:03

WebWork安裝WebWork配置

2009-07-09 16:22:12

WebWork配置

2009-07-10 11:02:17

WebWork參數配置

2009-07-08 09:29:58

WebWork

2009-07-14 15:52:00

WebWork文件下載

2009-07-16 16:51:56

WebWork驗證機制

2009-07-16 16:08:30

WebWork Act

2009-07-08 09:55:51

WebWork下載

2009-07-08 10:11:30

WebWork

2009-07-16 16:01:54

WebWork敏捷開發

2009-07-14 14:04:36

WebWork框架

2009-07-08 10:30:57

WebWork

2009-07-14 01:00:43

WebWorkActionConte

2009-07-16 16:27:26

Struts WebW

2009-07-14 12:47:07

WebWork工作方式
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 久久精品国产亚洲a | 免费在线观看av | 91网视频 | 日韩有码一区 | 日本久久精品视频 | 天堂一区 | 久久久久久国产精品久久 | 欧美亚洲日本 | 日韩国产在线 | 99久久久国产精品免费消防器 | 日韩精品在线一区 | 精品视频在线播放 | 麻豆久久精品 | 久久性av | 91精品国产综合久久久亚洲 | av日韩在线播放 | 成人三级网址 | 一区二区三区在线电影 | 欧美国产免费 | 一区二区三区四区av | 香蕉超碰 | 四虎影院新地址 | 日韩视频―中文字幕 | 成人欧美一区二区三区在线观看 | 精品久久久久久亚洲综合网 | 国产精品国产成人国产三级 | 亚洲第一在线 | 久久精品一区二区三区四区 | 久久精品国产99国产 | 91大神在线资源观看无广告 | 国产色| 91国语清晰打电话对白 | 红色av社区 | yeyeav | 91一区二区三区在线观看 | 一区二区高清 | 亚洲欧美视频一区 | 久久精品国产a三级三级三级 | 日韩成人久久 | 欧美成人精品在线 | 九色综合网 |