當下流行的兩種企業開發MVC開源架構,是我們Java程式猿必備知識能力。MVC,即模型(model)-視圖(view)-控制器(controller)的縮寫,一種軟體設計典範,用一種業務邏輯、資料、界面顯示分離的方法組織代碼,将業務邏輯聚集到一個部件裡面,在改進和個性化定制界面及使用者互動的同時,不需要重新編寫業務邏輯。架構之是以流行,在于其易複用和簡化開發,精髓在思想,掌握了核心思想,我們掌握其他類似架構也不會有問題,建議大家有精力的話讀一下架構源碼,尤其是Spring。
SSH和SSM定義
SSH 通常指的是 Struts2 做控制器(controller),spring 管理各層的元件,hibernate 負責持久化層。
SSM 則指的是 SpringMVC 做控制器(controller),Spring 管理各層的元件,MyBatis 負責持久化層。
共同點:1.Spring依賴注入DI來管理各層的元件。2.使用面向切面程式設計AOP管理事物、日志、權限等。
不同點:1.Struts2 和 SpringMVC 控制器(controller)控制視圖和模型的互動機制的不同,
Struts2是Action類級别,SpringMVC是方法級别,更容易實作RESTful風格。
SSH 和 SSM 的實作原理
1.Struts2 的實作原理
Struts2架構執行步驟(Struts2使用Filter嵌入):
1、用戶端初始化一個指向Servlet容器(例如Tomcat)的請求
2、這個請求經過一系列的過濾器(Filter)(這些過濾器中有一個叫做ActionContextCleanUp的可選過濾器,這個過濾器對于Struts2和其他架構的內建很有幫助
3、接着FilterDispatcher被調用,FilterDispatcher詢問ActionMapper來決定這個請求是否需要調用某個Action
4、如果ActionMapper決定需要調用某個Action,FilterDispatcher把請求的處理交給ActionProxy
5、ActionProxy通過Configuration Manager詢問架構的配置檔案,找到需要調用的Action類
6、ActionProxy建立一個ActionInvocation的執行個體。
7、ActionInvocation執行個體使用命名模式來調用,在調用Action的過程前後,涉及到相關攔截器(Intercepter)的調用。
8、一旦Action執行完畢,ActionInvocation負責根據struts.xml中的配置找到對應的傳回結果。傳回結果通常是(但不總是,也可 能是另外的一個Action鍊)一個需要被表示的JSP或者FreeMarker的模版。
9、将處理結果傳回給用戶端
2.SpringMVC 的實作原理
SpringMVC架構執行步驟(SpringMVC使用Servlet嵌入):
1、用戶端發出一個http請求給web伺服器,web伺服器對http請求進行解析,如果比對DispatcherServlet的請求映射路徑(在web.xml中指定),web容器将請求轉交給DispatcherServlet.
2、DipatcherServlet接收到這個請求之後将根據請求的資訊(包括URL、Http方法、請求封包頭和請求參數Cookie等)以及HandlerMapping的配置找到處理請求的處理器(Handler)。
3-4、DispatcherServlet根據HandlerMapping找到對應的Handler,将處理權交給Handler(Handler将具體的處理進行封裝),再由具體的HandlerAdapter對Handler進行具體的調用。
5、Handler對資料處理完成以後将傳回一個ModelAndView()對象給DispatcherServlet。
6、Handler傳回的ModelAndView()隻是一個邏輯視圖并不是一個正式的視圖,DispatcherSevlet通過ViewResolver将邏輯視圖轉化為真正的視圖View。
7、Dispatcher通過model解析出ModelAndView()中的參數進行解析最終展現出完整的view并傳回給用戶端。
Hibernate 和 MyBatis 兩種ORM架構對比
兩者的相同點
Hibernate與MyBatis都可以是通過SessionFactoryBuider由XML配置檔案生成SessionFactory,然後由SessionFactory 生成Session,最後由Session來開啟執行事務和SQL語句。其中SessionFactoryBuider,SessionFactory,Session的生命周期都是差不多的。
Hibernate和MyBatis都支援JDBC和JTA事務處理。
兩者各自優勢
MyBatis可以進行更為細緻的SQL優化,可以減少查詢字段。
MyBatis容易掌握,而Hibernate門檻較高。
Hibernate的DAO層開發比MyBatis簡單,Mybatis需要維護SQL和結果映射。
Hibernate對對象的維護和緩存要比MyBatis好,對增删改查的對象的維護要友善。
Hibernate資料庫移植性很好,MyBatis的資料庫移植性不好,不同的資料庫需要寫不同SQL。
Hibernate有更好的二級緩存機制,可以使用第三方緩存。MyBatis本身提供的緩存機制不佳,更新操作不能指定重新整理指定記錄,會清空整個表,但是也可以使用第三方緩存。
Hibernate 封裝性好,屏蔽了資料庫差異,自動生成SQL語句,應對資料庫變化能力較弱,SQL語句優化困難。
MyBatis僅實作了SQL語句和對象的映射,需要針對具體的資料庫寫SQL語句,應對資料庫變化能力較強,SQL語句優化較為友善。
總結
SSM和SSH不同主要在MVC實作方式,以及ORM持久化方面不同(Hiibernate與Mybatis)。SSM越來越輕量級配置,将注解開發發揮到極緻,且ORM實作更加靈活,SQL優化更簡便;而SSH較注重配置開發,其中的Hiibernate對JDBC的完整封裝更面向對象,對增删改查的資料維護更自動化,但SQL優化方面較弱,且入門門檻稍高。
附Spring家族: