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

細說MVC框架的幾大困惑

開發 后端
本篇文章主要生動的介紹了MVC框架,Struts2,Spring,Hibernate。似乎這些框架成為了一個人是否精通Java,是否會寫J2EE程序的唯一事實標準和找工作的必備基礎

現在許許多多的初學者和程序員,都在趨之若鶩地學習Web開發的寶典級框架:Struts2,Spring,Hibernate。似乎這些框架成為了一個人是否精通Java,是否會寫J2EE程序的***事實標準和找工作的必備基礎。

然而,如果在面試的時候問這些程序員,你們為什么要學習這些框架?這些框架的本質到底是什么?似乎很少很少有人能夠給我非常滿意的答復。因為他們都在為了學習而學習,為了工作而學習,而不是在真正去深入了解一個框架。其實所有的人都應該思考這樣的問題:為什么要學習框架?框架到底給我帶來了什么?接下來,我們以登錄作為一個最簡單的例子,來看看不同的年代,我們是怎么寫Web程序的

在很多年前,我們這么寫程序的

 

很多年前,那是一個貧苦的年代,如果我們要使用Java在網頁上做一些動態的交互功能。很多人會告訴你一個技術,叫做JSP。在我還對Java非常困惑的時候,就有人告訴我,JSP是個好東西,它可以在HTML代碼里面寫Java代碼來完成邏輯。

 

Html代碼

 

  1. <%     
  2.      String name = request.getParameter("name");     
  3.      String password = request.getParameter("password");     
  4.     
  5.      UserHandler userHandler = new UserHandler();     
  6.      if(userHandler.authenticate(name, password)) {     
  7. %>    
  8. <p>恭喜你,登錄成功</p>    
  9. <%     
  10.       } else {     
  11. %>    
  12. <p>對不起,登錄失敗</p>    
  13. <%     
  14.       }     
  15. %>   

作為一張JSP,它可以接收從別的JSP發送過來的登錄請求,并進行處理。這樣,我們不需要任何額外的配置文件,也不需要任何框架的幫忙,就能完成邏輯。

#p#

后來,我們放棄了在頁面上寫邏輯

 

后來,程序寫得越來越多,我們發現,這種在HTML代碼中編寫Java代碼來完成邏輯的方式存在著不少問題:

1. Java代碼由于混雜在一個HTML環境中而顯得混亂不堪,可讀性非常差。一個JSP文件有時候會變成幾十K,甚至上百K。要找一段邏輯,經常無法定位。

2. 編寫代碼時非常困惑,不知道代碼到底應該寫在哪里,也不知道別人是不是已經曾經實現過類似的功能,到哪里去引用。

3. 突然之間,某個需求發生了變化。于是,每個人蒙頭開始全程替換,還要小心翼翼的,生怕把別人的邏輯改了。

4. 邏輯處理程序需要自己來維護生命周期,對于類似數據庫事務、日志等眾多模塊無法統一支持。

在這個時候,如果有一個產品,它能夠將頁面上的那些Java代碼抽取出來,讓頁面上盡量少出現Java代碼,該有多好。于是許多人開始使用servlet來處理那些業務邏輯。

 

 

Java代碼

 

 

  1. public class LoginServlet extends HttpServlet {     
  2.     
  3.     /* (non-Javadoc)    
  4.      * @see javax.servlet.http.HttpServlet#doPost(javax.servlet.http.HttpServletRequest, javax.servlet.http.HttpServletResponse)    
  5.      */    
  6.     @Override    
  7.     protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {     
  8.         String message = null;     
  9.         RequestDispatcher dispatcher = req.getRequestDispatcher("/result.jsp");     
  10.         String name = req.getParameter("name");     
  11.         String password = req.getParameter("password");     
  12.              
  13.         UserHandler userHandler = new UserHandler();     
  14.         if(userHandler.authenticate(name, password)) {     
  15.             message = "恭喜你,登錄成功";     
  16.         } else {     
  17.             message = "對不起,登錄失敗";     
  18.         }     
  19.              
  20.         req.setAttribute("message", message);     
  21.         dispatcher.forward(req, resp);     
  22.     }     
  23. }    

在這里,我們需要在web.xml中為這個servlet配置url的請求關系。

 

Xml代碼

 

  1. <servlet>    
  2.   <servlet-name>Login</servlet-name>    
  3.     <servlet-class>    
  4.       com.demo2do.servlet.LoginServlet     
  5.   </servlet-class>    
  6. </servlet>    
  7. <servlet-mapping>    
  8.   <servlet-name>Login</servlet-name>    
  9.   <url-pattern>    
  10.     /Login     
  11.   </url-pattern>    
  12. </servlet-mapping>   

代碼重構到這里,我們發現,其實我們的工作量本身并沒有減少,只是代碼從JSP移動到了Servlet,使得整個流程看上去稍微清楚了一些。然而,為了這么點干凈,我們付出的代價是什么?為每個servlet都在web.xml里面去做一個url的請求配置!

#p#

再后來,出現框架

 

時代進一步發展,人們發現簡單的JSP和Servlet已經很難滿足人們懶惰的要求了。于是,人們開始試圖總結一些公用的Java類,來解決Web開發過程中碰到的問題。這時,橫空出世了一個框架,叫做struts。它非常先進地實現了MVC模式,成為了廣大程序員的福音。

struts的代碼示例我就不貼了,網上隨便搜搜你可以發現一堆一堆的。在一定程度上,struts能夠解決web開發中的職責分配問題,使得顯示與邏輯分開。不過在很長一段時間內,使用struts的程序員往往無法分別我們到底需要web框架幫我們做什么,我們到底需要它完成點什么功能?

#p#

我們到底要什么

 

在回顧了我們寫代碼的歷史之后,我們回過頭來看看,我們到底要什么?

無論是使用JSP,還是使用Struts1,或是Struts2,我們至少都需要一些必須的元素(如果沒有這些元素,或許我還真不知道這個程序會寫成什么樣子):

1. 數據

在這個例子中,就是name和password。他們共同構成了程序的核心載體。事實上,我們往往會有一個User類來封裝name和password,這樣會使得我們的程序更加OO。無論怎么說,數據會穿插在這個程序的各處,成為程序運行的核心。

2. 頁面展示

在這個例子中,就是login.jsp。沒有這個頁面,一切的請求、驗證和錯誤展示也無從談起。在頁面上,我們需要利用HTML,把我們需要展現的數據都呈現出來。同時我們也需要完成一定的頁面邏輯,例如,錯誤展示,分支判斷等等。

3. 處理具體業務的場所

在這里,不同階段,處理具體業務的場所就不太一樣。原來用JSP和Servlet,后來用Struts1或者Struts2的Action。

上面的這些必須出現的元素,在不同的年代,被賦予了不同的表現形式,有的受到時代的束縛,其表現形式非常落后,有的已經不再使用。但是撥開這些外在的表現形式,我們就可以發現,這不就是我們已經熟門熟路的MVC嘛?

數據 ———— Model

頁面展示 ———— View

處理具體業務的場所 ———— Control

所以,框架不重要,概念是王道。只要能夠深刻理解MVC的概念,框架對你來說,只是一個jar包而已。

MVC的概念其實就那么簡單,這些概念其實早已深入我們的內心,而我們所缺乏的是將其本質挖掘出來。我們來看看下面這幅圖,這是一副流行了很多年的講述MVC模型的圖: 

 

 

在這幅圖中,MVC三個框框各司其職,結構清晰明朗。不過我覺得這幅圖忽略了一個問題,就是數據是動的,數據在View和Control層一旦動起來,就會產生許多的問題:

1. 數據從View層傳遞到Control層,如何使得一個個扁平的字符串,轉化成一個個生龍活虎的Java對象

2. 數據從View層傳遞到Control層,如何方便的進行數據格式和內容的校驗?

3. 數據從Control層傳遞到View層,一個個生龍活虎的Java對象,又如何在頁面上以各種各樣的形式展現出來

4. 如果你試圖將數據請求從View層發送到Control層,你如何才能知道你要調用的究竟是哪個類,哪個方法?一個Http的請求,又如何與Control層的Java代碼建立起關系來?

除此之外,Control層似乎也沒有想象中的那么簡單,因為它作為一個控制器,至少還需要處理以下的問題:

1. 作為調用邏輯處理程序的facade門面,如果邏輯處理程序發生了異常,我們該如何處理?

2. 對于邏輯處理的結果,我們需要做怎么樣的處理才能滿足豐富的前臺展示需要?

這一個又一個問題的提出,都基于對MVC的基本概念的挖掘。所以,這些問題都需要我們在寫程序的時候去一一解決。說到這里,這篇文章開頭所提的問題應該可以有答案了:框架是為了解決一個又一個在Web開發中所遇到的問題而誕生的。不同的框架,都是為了解決不同的問題,但是對于程序員而言,他們只是jar包而已。框架的優缺點的評論,也完全取決于其對問題解決程度和解決方式的優雅性的評論。所以,千萬不要為了學習框架而學習框架,而是要為了解決問題而學習框架,這才是一個程序員的正確學習之道。

【編輯推薦】

 

責任編輯:金賀 來源: JavaEye博客
相關推薦

2018-08-07 15:13:44

小程序微信品牌

2009-12-07 18:06:46

WCF框架

2010-01-08 12:03:42

ibmdwREST

2012-10-22 16:55:48

JavaMVC

2017-11-23 17:21:31

Yii框架IntelYii框架深度剖析

2009-06-19 11:43:59

Spring MVC框

2009-04-24 09:43:09

.NETASP.NET框架

2009-07-22 10:34:37

ActionInvokASP.NET MVC

2009-02-02 09:04:52

MVC框架Java

2009-12-14 10:19:23

.NET Framew

2009-02-02 09:08:38

MVC框架控制器CakePHP

2013-03-21 13:56:21

JavaScriptBackBone

2009-06-19 11:28:45

2009-07-24 13:20:44

MVC框架ASP.NET

2010-06-23 15:44:03

ASP.NET MVC

2010-01-07 09:59:16

RESTMVC

2009-09-25 15:15:17

算法

2011-05-06 16:19:18

網絡打印優勢

2011-04-15 10:26:38

JavaMVC

2012-11-28 11:05:42

IBMdW
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 黄色a三级 | 久久伊| 色狠狠一区 | av一区在线| 欧美操操操| 91麻豆精品国产91久久久久久 | 国产精品美女久久久久久久网站 | 国产亚洲久 | 亚洲成网站 | 天天精品在线 | 欧美a在线观看 | 久久精品国产一区 | 欧美成ee人免费视频 | 午夜黄色| 99精品在线观看 | 在线观看毛片网站 | 国产精品一区二区三区四区 | 在线观看国产wwwa级羞羞视频 | 在线免费中文字幕 | 美日韩中文字幕 | 国产福利在线 | 亚洲国产成人精品女人久久久野战 | 91九色视频 | 国产玖玖| 黑人久久久| 精品亚洲一区二区 | 日韩不卡在线观看 | 国产精品久久久久久久久久久久 | 蜜桃臀av一区二区三区 | 久久一级免费视频 | 国产精品一区二区在线免费观看 | 欧美日韩免费视频 | 91毛片在线看 | 狠狠色香婷婷久久亚洲精品 | 亚洲一区 | 日韩欧美电影在线 | www.婷婷亚洲基地 | 中文字幕一区二区在线观看 | 久久久久久久久久一区二区 | 日韩av在线一区 | 久久成人国产 |