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

高手支招 Java經驗分享(十)

開發 后端
本篇文章是作者Ant_Yan在CSDN論壇上發布的自己對Java學習的一些經驗分享。這是他經驗分享的第十部分。

  這篇是筆者Java學習經驗分享的第十篇,這次準備繼續上次的話題先講講Struts-2。首先簡短回顧一段歷史:隨著時間的推移,Web應用框架經常變化的需求,產生了幾個下一代Struts的解決方案。其中的Struts Ti 繼續堅持 MVC模式的基礎上改進,繼續Struts的成功經驗WebWork項目是在2002年3月發布的,它對Struts式框架進行了革命性改進,引進了不少新的思想,概念和功能,但和原Struts代碼并不兼容。WebWork是一個成熟的框架,經過了好幾次重大的改進與發布。在2005年12月,WebWork與Struts Ti決定合拼,再此同時,Struts Ti 改名為 Struts Action Framework 2.0,成為Struts真正的下一代。

  看看Struts-2的處理流程:

  1) Browser產生一個請求并提交框架來處理:根據配置決定使用哪些攔截器、action類和結果等。

  2) 請求經過一系列攔截器:根據請求的級別不同攔截器做不同的處理。這和Struts-1的RequestProcessor類很相似。

  3) 調用Action: 產生一個新的action實例,調用業務邏輯方法。

  4) 調用產生結果:匹配result class并調用產生實例。

  5) 請求再次經過一系列攔截器返回:過程也可配置減少攔截器數量

  6) 請求返回用戶:從control返回servlet,生成Html。

  這里很明顯的一點是不存在FormBean的作用域封裝,直接可以從Action中取得數據。 這里有一個Strut-2配置的web.xml文件:

  1. <filter> 
  2.     <filter-name>   controller   </filter-name>        
  3.     <filter-class>   org.apache.struts.action2.dispatcher.FilterDispatcher    </filter-class>     
  4. </filter>     
  5. <filter-mapping>         
  6.     <filter-name>   cotroller   </filter-name>         
  7.     <url-pattern>   /*   </url-pattern>     
  8. </filter-mapping> 

  注意到以往的servlet變成了filter,ActionServlet變成了FilterDispatcher,*.do變成了/*。filter配置定義了名稱(供關聯)和filter的類。filter mapping讓URI匹配成功的的請求調用該filter。默認情況下,擴展名為 ".action "。這個是在default.properties文件里的 "struts.action.extension "屬性定義的。

  default.properties是屬性定義文件,通過在項目classpath路徑中包含一個名為“struts.properties”的文件來設置不同的屬性值。而Struts-2的默認配置文件名為struts.xml。由于1和2的action擴展名分別為.do和.action,所以很方便能共存。我們再來看一個Struts-2的action代碼:

  1. public class MyAction {  
  2.   public String execute() throws Exception {  
  3.   //do the work  
  4.   return "success ";  
  5.   }  
  6. }  
  7.  
  8.     

  很明顯的區別是不用再繼承任何類和接口,返回的只是一個String,無參數。實際上在Struts-2中任何返回String的無參數方法都可以通過配置來調用action。所有的參數從哪里來獲得呢?答案就是Inversion of Control技術(控制反轉)。筆者盡量以最通俗的方式來解釋,我們先試圖讓這個Action獲得reuqest對象,這樣可以提取頁面提交的任何參數。那么我們把request設為一個成員變量,然后需要一個對它的set方法。由于大部分的action都需要這么做,我們把這個set方法作為接口來實現。

  1. public interface ServletRequestAware {  
  2.   public void setServletRequest(HttpServletRequest request);  
  3. }  
  4. public class MyAction implements ServletRequestAware {  
  5.   private HttpServletRequest request;  
  6.   public void setServletRequest(HttpServletRequest request) {  
  7.   this.request = request;  
  8.   }  
  9.   public String execute() throws Exception {  
  10.   // do the work directly using the request  
  11.   return Action.SUCCESS;  
  12.   }  

  那么誰來調用這個set方法呢?也就是說誰來控制這個action的行為,以往我們都是自己在適當的地方寫上一句action.setServletRequest(…),也就是控制權在程序員這邊。然而控制反轉的思想是在哪里調用交給正在運行的容器來決定,只要利用Java反射機制來獲得Method對象然后調用它的invoke方法傳入參數就能做到,這樣控制權就從程序員這邊轉移到了容器那邊。程序員可以減輕很多繁瑣的工作更多的關注業務邏輯。Request可以這樣注入到action中,其他任何對象也都可以。為了保證action的成員變量線程安全,Struts-2的action不是單例的,每一個新的請求都會產生一個新的action實例。

  那么有人會問,到底誰來做這個對象的注入工作呢?答案就是攔截器。攔截器又是什么東西?筆者再來盡量通俗的解釋攔截器的概念。大家要理解攔截器的話,首先一定要理解GOF23種設計模式中的Proxy模式。

  A對象要調用f(),它希望代理給B來做,那么B就要獲得A對象的引用,然后在B的f()中通過A對象引用調用A對象的f()方法,最終達到A的f()被調用的目的。有沒有人會覺得這樣很麻煩,為什么明明只要A.f()就可以完成的一定要封裝到B的f()方法中去?有哪些好處呢?

  1) 這里我們只有一個A,當我們有很多個A的時候,只需要監視B一個對象的f()方法就可以從全局上控制所有被調用的f()方法。

  2) 另外,既然代理人B能獲得A對象的引用,那么B可以決定在真正調A對象的f()方法之前可以做哪些前置工作,調完返回前可有做哪些后置工作。

  講到這里,大家看出來一點攔截器的概念了么?它攔截下一調f()方法的請求,然后統一的做處理(處理每個的方式還可以不同,解析A對象就可以辨別),處理完畢再放行。這樣像不像對流動的河水橫切了一刀,對所有想通過的水分子進行搜身,然后再放行?這也就是AOP(Aspect of Programming面向切面編程)的思想。

  Anyway,Struts-2只是利用了AOP和IoC技術來減輕action和框架的耦合關系,力圖到***程度重用action的目的。在這樣的技術促動下,Struts-2的action成了一個簡單被框架使用的POJO(Plain Old Java Object)罷了。實事上AOP和IoC的思想已經遍布新出來的每一個框架上,他們并不是多么新的技術,利用的也都是JDK早已可以最到的事情,它們代表的是更加面向接口編程,提高重用,增加擴展性的一種思想。Struts-2只是部分的使用這兩種思想來設計完成的,另外一個最近很火的框架Spring,更大程度上代表了這兩種設計思想,筆者將于下一篇來進一步探討Spring的結構。

  附言: 關于Struts-2筆者也沒真正怎么用過,這里是看了網上一些前輩的帖子之后寫下自己的學習體驗,不足之處請見諒!

【編輯推薦】

  1. 新手入門:學習Java的一點經驗心得
  2. 61條Java面向對象設計的經驗原則
  3. 經驗分享:我的JavaEE學習道路
  4. Java對象類型轉換的四個經驗
  5. 高手支招 Java經驗分享(一)
責任編輯:韓亞珊 來源: CSDN
相關推薦

2011-03-31 13:52:22

Java

2011-03-31 13:32:13

Java

2011-03-31 13:56:24

Java

2011-03-31 14:07:27

Java

2011-03-31 14:49:35

2011-03-31 15:36:02

Java

2011-03-31 16:44:43

Java

2011-03-31 16:49:40

Java

2011-04-07 13:18:00

管理軟件項目項目

2009-10-29 16:57:05

Oracle傳輸表空間

2009-04-08 10:51:59

SQL優化經驗

2018-06-19 08:12:55

2010-07-21 14:05:31

2014-05-28 10:55:11

Windows XP安全補丁

2013-01-08 09:25:36

移動應用產品設計

2011-07-13 18:09:07

編程語言

2010-08-18 14:19:01

無線路由器

2009-09-28 10:52:00

CCNA考試經驗CCNA

2011-07-10 16:23:22

SEO內鏈外鏈

2013-07-26 13:23:28

點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 自拍偷拍亚洲视频 | 国产一区二区日韩 | 99热在线免费 | 欧美99| 久久草在线视频 | 欧美极品在线播放 | 国产精品18毛片一区二区 | 精品国产亚洲一区二区三区大结局 | 成人精品鲁一区一区二区 | 久久久久网站 | 一级黄色毛片 | 99亚洲国产精品 | 日本黄色免费片 | 99爱在线 | 亚洲天堂中文字幕 | 91在线看片 | 亚洲aⅴ| 精品国产欧美一区二区 | 欧美日韩中文字幕 | 狠狠做六月爱婷婷综合aⅴ 国产精品视频网 | 最新91在线 | 国产精品美女www爽爽爽视频 | 一区二区三区视频免费看 | 黄色一级毛片免费看 | 中文字幕在线观看视频网站 | 高清黄色网址 | 男女下面一进一出网站 | 日韩福利在线 | 久久久国产一区 | 亚洲国产网 | 久久精品亚洲精品国产欧美 | 五月天国产 | 九九久久免费视频 | 成人在线视频免费看 | 一区在线视频 | 91国产精品 | 亚洲视频1区 | 一区二区精品 | 午夜影视大全 | 久久99精品国产自在现线小黄鸭 | 7799精品视频天天看 |