一、攔截機制的不同Struts2是類級別的攔截,每次請求就會創(chuàng)建一個Action,和Spring整合時Struts2的ActionBean注入作用域是原型模式prototype,然后通過setter,getter吧request數(shù)據(jù)注入到屬性。Struts2中,一個Action對應(yīng)一個request,response上下文,在接收參數(shù)時,可以通過屬性接收,這說明屬性參數(shù)是讓多個方法共享的。Struts2中Action的一個方法可以對應(yīng)一個url,而其類屬性卻被所有方法共享,這也就無法用注解或其他方式標(biāo)識其所屬方法了,只能設(shè)計為多例。 SpringMVC是方法級別的攔截,一個方法對應(yīng)一個Request上下文,所以方法直接基本上是獨立的,獨享request,response數(shù)據(jù)。而每個方法同時又何一個url對應(yīng),參數(shù)的傳遞是直接注入到方法中的,是方法所獨有的。處理結(jié)果通過ModeMap返回給框架。在Spring整合時,SpringMVC的Controller Bean默認單例模式Singleton,所以默認對所有的請求,只會創(chuàng)建一個Controller,有應(yīng)為沒有共享的屬性,所以是線程安全的,如果要改變默認的作用域,需要添加@Scope注解修改。 Struts2有自己的攔截Interceptor機制,SpringMVC這是用的是獨立的Aop方式,這樣導(dǎo)致Struts2的配置文件量還是比SpringMVC大。 二、底層框架的不同Struts2采用Filter(StrutsPrepareAndExecuteFilter)實現(xiàn),SpringMVC(DispatcherServlet)則采用Servlet實現(xiàn)。Filter在容器啟動之后即初始化;服務(wù)停止以后墜毀,晚于Servlet。Servlet在是在調(diào)用時初始化,先于Filter調(diào)用,服務(wù)停止后銷毀。 三、性能方面Struts2是類級別的攔截,每次請求對應(yīng)實例一個新的Action,需要加載所有的屬性值注入,SpringMVC實現(xiàn)了零配置,由于SpringMVC基于方法的攔截,有加載一次單例模式bean注入。所以,SpringMVC開發(fā)效率和性能高于Struts2。 四、配置方面spring MVC和Spring是無縫的。從這個項目的管理和安全上也比Struts2高。
附注:攔截器與過濾器的區(qū)別 :
|
|
來自: 一本正經(jīng)地胡鬧 > 《框架》