FreeMarker是一個(gè)模板引擎,一個(gè)基于模板生成文本輸出的通用工具,使用純Java編寫(xiě)
FreeMarker被設(shè)計(jì)用來(lái)生成HTML Web頁(yè)面,特別是基于MVC模式的應(yīng)用程序
雖然FreeMarker具有一些編程的能力,但通常由Java程序準(zhǔn)備要顯示的數(shù)據(jù),由FreeMarker生成頁(yè)面,通過(guò)模板顯示準(zhǔn)備的數(shù)據(jù)。
FreeMarker不是一個(gè)Web應(yīng)用框架,而適合作為Web應(yīng)用框架一個(gè)組件
FreeMarker與容器無(wú)關(guān),因?yàn)樗⒉恢繦TTP或Servlet;FreeMarker同樣可以應(yīng)用于非Web應(yīng)用程序環(huán)境
FreeMarker更適合作為Model2框架(如Struts)的視圖組件,你也可以在模板中使用JSP標(biāo)記庫(kù)
FreeMarker是免費(fèi)的
1、通用目標(biāo)
能夠生成各種文本:HTML、XML、RTF、Java源代碼等等
易于嵌入到你的產(chǎn)品中:輕量級(jí);不需要Servlet環(huán)境
插件式模板載入器:可以從任何源載入模板,如本地文件、數(shù)據(jù)庫(kù)等等
你可以按你所需生成文本:保存到本地文件;作為Email發(fā)送;從Web應(yīng)用程序發(fā)送它返回給Web瀏覽器
2、強(qiáng)大的模板語(yǔ)言
所有常用的指令:include、if/elseif/else、循環(huán)結(jié)構(gòu)
在模板中創(chuàng)建和改變變量
幾乎在任何地方都可以使用復(fù)雜表達(dá)式來(lái)指定值
命名的宏,可以具有位置參數(shù)和嵌套內(nèi)容
名字空間有助于建立和維護(hù)可重用的宏庫(kù),或者將一個(gè)大工程分成模塊,而不必?fù)?dān)心名字沖突
輸出轉(zhuǎn)換塊:在嵌套模板片段生成輸出時(shí),轉(zhuǎn)換HTML轉(zhuǎn)義、壓縮、語(yǔ)法高亮等等;你可以定義自己的轉(zhuǎn)換
3、通用數(shù)據(jù)模型
freeMarker不是直接反射到Java對(duì)象,Java對(duì)象通過(guò)插件式對(duì)象封裝,以變量方式在模板中顯示
你可以使用抽象(接口)方式表示對(duì)象(JavaBean、XML文檔、SQL查詢結(jié)果集等等),告訴模板開(kāi)發(fā)者使用方法,使其不受技術(shù)細(xì)節(jié)的打擾
4、為Web準(zhǔn)備
- 在模板語(yǔ)言中內(nèi)建處理典型Web相關(guān)任務(wù)(如HTML轉(zhuǎn)義)的結(jié)構(gòu)
- 能夠集成到Model2 Web應(yīng)用框架中作為JSP的替代
- 支持JSP標(biāo)記庫(kù)
- 為MVC模式設(shè)計(jì):分離可視化設(shè)計(jì)和應(yīng)用程序邏輯;分離頁(yè)面設(shè)計(jì)員和程序員
5、智能的國(guó)際化和本地化
- 字符集智能化(內(nèi)部使用UNICODE)
- 數(shù)字格式本地化敏感
- 日期和時(shí)間格式本地化敏感
- 非US字符集可以用作標(biāo)識(shí)(如變量名)
- 多種不同語(yǔ)言的相同模板
6、強(qiáng)大的XML處理能力
<#recurse> 和<#visit>指令(2.3版本)用于遞歸遍歷XML樹(shù)
在模板中清楚和直覺(jué)的訪問(wèn)XML對(duì)象模型
Helloworld
新建一個(gè)WEB工程,下載(我使用的是freemarker-2.3.20)freemarker并導(dǎo)入freemarker.jar,在WEB-INF下新建文件夾templates用于存放模版文件
在templates下新建test.ftl,這是示例模版文件。內(nèi)容就是HTML內(nèi)容,里面帶有一個(gè)標(biāo)記符,用于將來(lái)進(jìn)行變量替換,內(nèi)容如下:
1
2
3
4
5
6
7
8
|
< html > < head > < title >freemarker測(cè)試</ title > </ head > < body > < h1 >${message},${name}</ h1 > </ body > </ html > |
新建一個(gè)Servlet,用于請(qǐng)求設(shè)置變量,并處理模版的輸出:
1
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
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
|
package com.test.servlet; import java.io.IOException; import java.io.Writer; import java.util.HashMap; import java.util.Map; import javax.servlet.ServletException; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import freemarker.template.Configuration; import freemarker.template.Template; import freemarker.template.TemplateException; @SuppressWarnings ( "serial" ) public class HelloFreeMarkerServlet extends HttpServlet { // 負(fù)責(zé)管理FreeMarker模板的Configuration實(shí)例 private Configuration cfg = null ; public void init() throws ServletException { // 創(chuàng)建一個(gè)FreeMarker實(shí)例 cfg = new Configuration(); // 指定FreeMarker模板文件的位置 cfgsetServletContextForTemplateLoading(getServletContext(), "/WEB-INF/templates" ); } @SuppressWarnings ( "unchecked" ) public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { // 建立數(shù)據(jù)模型 Map root = new HashMap(); root.put( "message" , "hello world" ); root.put( "name" , "java小強(qiáng)" ); // 獲取模板文件 Template t = cfg.getTemplate( "test.ftl" ); // 使用模板文件的Charset作為本頁(yè)面的charset // 使用text/html MIME-type responsesetContentType( "text/html; charset=" + tgetEncoding()); Writer out = response.getWriter(); // 合并數(shù)據(jù)模型和模板,并將結(jié)果輸出到out中 try { tprocess(root, out); // 往模板里寫(xiě)數(shù)據(jù) } catch (TemplateException e) { e.printStackTrace(); } } public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { doPost(request, response); } public void destroy() { super .destroy(); } } |
注意要在你的web.xml中配置該Servlet:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
<? xml version = "1.0" encoding = "UTF-8" ?> < web-app version = "2.5" xmlns = "http://java.sun.com/xml/ns/javaee" xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"> < servlet > < servlet-name >hello</ servlet-name > < servlet-class > com.test.servlet.HelloFreeMarkerServlet </ servlet-class > </ servlet > < servlet-mapping > < servlet-name >hello</ servlet-name > < url-pattern >/hello</ url-pattern > </ servlet-mapping > < welcome-file-list > < welcome-file >index.jsp</ welcome-file > </ welcome-file-list > </ web-app > |
為了方便測(cè)試,訪問(wèn)工程直接跳轉(zhuǎn)到Servlet,對(duì)主頁(yè)index.jsp做一個(gè)簡(jiǎn)單修改:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
<%@ page language= "java" import = "java.util.*" pageEncoding= "UTF-8" %> <% String path = request.getContextPath(); String basePath = request.getScheme()+ "://" +request.getServerName() + ":" +request.getServerPort()+path+ "/" ; %> <html> <body> <% String mypath = "hello" ; response.sendRedirect(basePath + mypath); %> </body> </html> |