關于freemark FreeMarker是Quake Wang推薦我使用的。剛學FreeMarker的時候,發現freemarker真的很棒!簡單易用,功能強大。但是用它做了幾個項目以后開始不爽了。
一宗罪:freemarker的變量必須有值,沒有被賦值的變量就會拋出異常,那個黃黃的freemarker出錯頁面,真是讓人看了太難過了。
freemarker的
FAQ上面冠冕堂皇的說,未賦值的變量強制拋錯可以杜絕很多潛在的錯誤,如缺失潛在的變量命名,或者其他變量錯誤。但是實際的效果是:帶來的是非常大的編
程麻煩,程序里面幾乎所有可能出現空值的變量統統需要加上${xxx?if_exists},有些循環條件還需要寫if判斷,這樣不但沒有杜絕應該杜絕的
錯誤,反而極大增加了編程的麻煩。
二宗罪:freemarker的map限定key必須是string,其他數據類型竟然無法操作!這一點就不講了,JavaEye上面已經有人抱怨過了。連Webwork的開發人員Pat Lightboy都在抱怨這一點。
三宗罪:freemarker為了編程方便把不可序列化的東西往session里面放!
freemarker支持在頁面里面直接操作Session,request等,例如${Session[...]},方便確實很方便,但是一旦需要做群集,就會報錯。
今天是b051問起我這個問題,他在做Tomcat群集的時候發現freemarker報錯,HttpSessionHashModel不可序列化。他修改該類源代碼,讓他實現序列化接口,仍然報錯。我一看,HttpSessionHashModel包含的屬性:
- private HttpSession session;
- private final ObjectWrapper wrapper;
-
-
- private final FreemarkerServlet servlet;
- private final HttpServletRequest request;
- private final HttpServletResponse response;
登時暈倒,這樣的東西還往Session里面放?bad smell!
嚴重警告應用需要往群集上面發布應用的同學們,千萬別用freemarker!
不過瑕不掩瑜,freemarker也是有優點的:
1、易學易用
我是看了一天文檔就用得挺熟練了,freemarker文檔寫得太好了,例子豐富,照做一遍全都會了。
2、功能強大
比Velocity強大多了,還支持JSP Tag。不過最有意義的是macro功能,可以自定義常用的macro,實現頁面常規操作的可復用性。
3、報錯信息友好
很多應用服務器的JSP報錯信息是無法定位到源代碼行的。不過freemarker報錯定位很準確,絲毫不差,而且信息豐富,一看就知道怎么回事(雖然那個黃黃的頁面看起來讓人難受) ExtJS教程- Hibernate教程- Struts2 教程- Lucene教程
|
|
|