這是[挑戰(zhàn)MVC極限]EasyJWeb-1.0特性的第四篇文章,今天主要介紹零配置及慣例代替配置。
配置是好還是壞
首先,我承認(rèn)配置是好東西,它能夠通過修改程序以外的數(shù)據(jù)來改變系統(tǒng)的運(yùn)行性質(zhì)或功能,大大提高了系統(tǒng)的靈活性,可維護(hù)性,從而延長了一個系統(tǒng)的存活期。
跟其它任何事情一樣,物極必反。當(dāng)一個好的東西泛濫成災(zāi)的時候,我們也會產(chǎn)生厭惡,走向另外一個極端。而縱觀今天我們正統(tǒng)的JavaEE應(yīng)用,配置可謂無處不在,由于過分的強(qiáng)調(diào)了靈活性、可擴(kuò)展性、可選擇性,大到Spring小到log4j的各種框架、輔助工具都會提供配置文件來改變他們的運(yùn)行屬性。一個JavaEE應(yīng)用往往需要到很多的框架及輔助工具,比如Spring的bean配置文件、dwr配置文件,hibernate的對象-關(guān)系映射文件、struts的配置文件、驗(yàn)證文件等。好大一堆啊,我們看看appfuse中的配置文件,而維護(hù)這些配置文件,并非一個簡單的事兒。
如何簡化配置
為了解決過度“配置”給我們帶來的配置恐懼病,唯一的辦法是簡化配置。
我們?nèi)绾魏喕渲茫古渲帽M量的少,盡量的簡單,甚至把配置減到零呢?在整個java社區(qū),有很多人在做著這樣事兒。減化的流程大致如下:
第一步:使用注解,把不是頻繁變動的配置信息從外部配置文件遷移到與這些配置緊密聯(lián)系的java文件中,可以減少2/3以上的配置信息。
第二步:一些具有很多習(xí)慣性的配置屬性,可以通過慣例約定的方式,來代替配置,從而又可以減掉一部分配置。
第三步:最后余下的即是跟程序運(yùn)行環(huán)境緊密相關(guān),易變的配置文件。比如針對數(shù)據(jù)庫連接信息dataSource的配置。
這樣就可以在不影響系統(tǒng)的靈活性、可擴(kuò)展性、移植性的情況下,最大限度地減化了配置。
零配置
EasyJWeb在開發(fā)的過程中,在配置處理上,一直把減化配置作為一個重點(diǎn)注意事項(xiàng),并實(shí)現(xiàn)了零配置。有了零配置支持,你可以不寫一句配置文件,就能實(shí)現(xiàn)立體感超強(qiáng)的JavaEE應(yīng)用。dao、service、module、action等,都會按照慣例約定的方式來工作。
比如,我們需要寫一個用戶登錄的Action,可以在com.easyjweb.action這個包下面,添加一個名為LoginAction的類,可以繼承AbstractPageAction或者直接實(shí)現(xiàn)IWebAction接口。 使用AbstractPageAction能自動識別模板,實(shí)現(xiàn)起來最簡單,代碼內(nèi)容如下:public class NewsAction extends AbstractPageCmdAction ...{
public Page login(WebForm form,Module module)
...{
if("xiaoxiao".equals(form.get("name"))&&"123".equals(form.get("password")))
...{
return module.findPage("success");
}
else return module.findPage("index");
}
在WEB-INF/views/login/目錄中,存放兩個文件,一個是名為index.html,主要是登錄表單;另外一個是success.html,內(nèi)容為登錄成功提示頁面。
這樣即可通過/login.ejf來訪問這個登錄應(yīng)用。
由此可見,我們確實(shí)不需要一句配置文件,就能讓EasyJWeb這個MVC框架運(yùn)轉(zhuǎn)起來。
慣例(約定)代替配置
在上面“零配置”示例中,我們沒有使用一句配置文件,在這里EasyJWeb中的“慣例(約定)代替配置”功能起了非常大的作用。按約定方式來尋找Action、尋找視圖模板頁面。才使得mvc能工作起來。
慣例代替配置,可以大大提高軟件的生產(chǎn)力。在EasyJWeb中,很多地方都使用慣例代替配置,下面進(jìn)一步介紹智能頁面查詢,這是一個慣例代替配置的例子。
在一個基于AbstractPageCmdAction的模塊PersonAction中,有下面的方法:








其中doEdit方法中可以不包含一句代碼,也不需要有任何視圖模板的代碼。EasyJWeb在沒有找到針對該模塊相關(guān)Page配置的情況下,此時會自動應(yīng)用“慣例代替配置”的功能,從而找到/views/person/edit.html作為doEdit的頁面模板;同理,EasyJWeb的“慣例代替配置”還會把/views/person/list.html作為doList的頁面模板。
除了模板以外,在代碼生成,JPA Entity標(biāo)簽處理、通用業(yè)務(wù)封裝,驗(yàn)證等均引入了“慣例代替配置”。在我們的實(shí)踐中,“慣例代替配置”確實(shí)是一個非常牛的東西,他們幫我們省了很多事兒。