SSH流行很久了,一直看到官方文檔和網(wǎng)上都在講如何整合SSH,討論各種整合的優(yōu)缺點(diǎn)。今天我比較閑,也用我的一些想法來(lái)試著整合這三個(gè)最流行的框架。
本次所用版本為:Struts 1.3.9???Spring 2.5???Hiberante 3.2
開(kāi)發(fā)工具和環(huán)境為:Eclipse 3.3+MyEclipse 6.0+JBoss 4.2+Tomcat
用SSH時(shí),我們的架構(gòu)自然就會(huì)分成三層,即表現(xiàn)層,邏輯層和持久層,按照Martin Flower的指導(dǎo)思想,耦合越少越好,下層為上層提供服務(wù),這也是Rod開(kāi)發(fā)Spring的指導(dǎo)思想之一,所以我首先想到的就是如何減少到最低的耦合。
根據(jù)Spring 2.0官方文檔中推薦的做法,Spring與Struts1.x集成,有采用代理類的方式,也有用ActionSupport的方式,但是我認(rèn)為這兩種方式無(wú)疑都有很強(qiáng)的侵入性和依賴性,這與Spring的思想有些矛盾。
我采用AutowiringRequestProcessor來(lái)做,這個(gè)類會(huì)自動(dòng)為你裝載你所需要的Service,根據(jù)其Java Doc的提示,其默認(rèn)是byType匹配的,當(dāng)然你也可以用byName的方式,我認(rèn)為以Type的方式就OK了。來(lái)看看兩個(gè)配置文件吧,先來(lái)看看Struts的配置文件struts-config.xml:

?2

?3

?4

?5

?6

?7

?8

?9

10

11

12

13

14

15

16

17

18

19

20

21

22

這個(gè)文件中可以發(fā)現(xiàn),跟沒(méi)有與Spring集成時(shí)就一點(diǎn)不一樣,多了一行:
?<controller??processorClass="org.springframework.web.struts.AutowiringRequestProcessor" />
再來(lái)看看Spring的配置文件applicationContext.xml:

?2

?3

?4

?5

?6

?7

?8

?9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

這里面也沒(méi)有多余的內(nèi)容,不會(huì)出現(xiàn)代理方式時(shí),多份XML同時(shí)配置的問(wèn)題,減少了維護(hù)量。
同時(shí),你會(huì)發(fā)現(xiàn),我并沒(méi)有把Hibernate的具體配置放在這里面,而是用Hibernate自身的配置來(lái)管理。
這樣的話,我們?nèi)龑又g的依賴性會(huì)降到較低,兩頭可以任意換到其中的某一層。
順便要說(shuō)的是,常見(jiàn)的書籍上面發(fā)現(xiàn)往往不會(huì)有如此深入的探討,難道是怕初學(xué)者看不懂嗎?
另外,對(duì)于一個(gè)架構(gòu)來(lái)說(shuō),要解決的問(wèn)題決不是指這些,通常我們可以采用RUP的4+1視圖的方法去考慮架構(gòu)的方方面面。我們也可以從以下一些方面來(lái)各個(gè)擊破:安全性,數(shù)據(jù)輸入輸出的校驗(yàn)與轉(zhuǎn)換,國(guó)際化,LOG,異常處理,異構(gòu)系統(tǒng)整合,后臺(tái)運(yùn)行程序等等。如果是多個(gè)數(shù)據(jù)庫(kù),我們還需要更多的考慮事務(wù)控制。
我想我后面會(huì)去完善這個(gè)整合,并實(shí)現(xiàn)一個(gè)Demo,作為小的簡(jiǎn)單的項(xiàng)目快速開(kāi)發(fā)的基礎(chǔ)。
整合時(shí)遇到過(guò)如下問(wèn)題:
問(wèn)題1:?jiǎn)?dòng)時(shí)出現(xiàn) “嚴(yán)重: Error listenerStart ”
這個(gè)問(wèn)題,網(wǎng)上有很多解決辦法:
有一種最簡(jiǎn)單的解決辦法是把用Listener初始化Spring改為用Servlet初始化Spring,但這樣的方法不太好,一是沒(méi)有找到根源,二是可能會(huì)帶來(lái)新的問(wèn)題。
比較好的一種解決辦法是,加上Log4J的相關(guān)配置,然后再啟動(dòng)時(shí),就會(huì)出現(xiàn)各類詳細(xì)信息,這樣可根據(jù)具體信息再來(lái)解決,一般可能是DataSource配置,或環(huán)境配置有問(wèn)題。
參考網(wǎng)址:http://hi.baidu.com/xht314/blog/item/808ecf13c1dd1820dd5401af.html
問(wèn)題2:遇到“Required extension qdox not found”這樣的提示
網(wǎng)上也有解答,我用的方法是直接把commons-attributes-compiler.jar這個(gè)包去掉。當(dāng)然如果你要用到這個(gè)包的話,可以參考下面這個(gè)地址:
http://hi.baidu.com/sky_lei/blog/item/77ee17085543b232e8248824.html
問(wèn)題3:Struts包與Spring包沖突的問(wèn)題
我遇到包有沖突,換成Struts需要的優(yōu)先就OK了,現(xiàn)在的JAR檔越來(lái)越麻煩了,很多項(xiàng)目的JAR檔都被開(kāi)發(fā)人員搞得亂七八糟,看來(lái)Maven是個(gè)好東西,至少思想是好的,可能下一步需要研究一下。