FreeMarker是一个用Java语言编写的模板引擎,它基于模板来生成文本输出。FreeMarker与Web容器无关,即在Web运行时,它并不知道Servlet或HTTP。它不仅可以用作表现层的实现技术,而且还可以用于生成XML,JSP或Java 等。
一个简单的使用FreeMarker的项目过程:
1. 使用myeclipse创建一个web项目test。
2. 把下载到的jar包(freemarker-2.3.18.jar)放到\WebRoot\WEB-INF\lib目录下。
3. 在WebRoot下面新建templates文件包,然后在里面新建扩展名为ftl的模板。
创建hello.ftl内容如下:
<html> <head> <title>hello!</title> </head> <body> <h1>hello ${user}!</h1> </body> </html>
4. 在src目录下创建example包和Hello.java文件,代码如下:
package example; import java.io.*; import java.util.*; import javax.servlet.ServletException; import javax.servlet.http.*; import freemarker.template.*; public class Hello extends HttpServlet{ private Configuration cfg; public void init() { //初始化FreeMarker配置 //创建一个Configuration实例 cfg = new Configuration(); //设置FreeMarker的模版文件位置 cfg.setServletContextForTemplateLoading(getServletContext(),"templates"); } public void doGet(HttpServletRequest request,HttpServletResponse response) throws ServletException,IOException { //建立数据模型 Map root = new HashMap(); //放入对应数据key value root.put("user","Csyor"); //取得模版文件 Template t =cfg.getTemplate("hello.ftl"); // FreeMarker会到系统的/WebRoot/templates/目录下找hello.ftl文件 //开始准备生成输出 //使用模版文件的charset作为本页面的charset //使用text/html MIME-type response.setContentType("text/html; charset=" + t.getEncoding()); PrintWriter out = response.getWriter(); //合并数据模型和模版,并将结果输出到out中 try { t.process(root,out);// 用模板来开发servlet可以只在代码里面加入动态的数据 } catch(TemplateException e) { throw new ServletException("处理Template模版中出现错误", e); } } }
5.配置web.xml 代码如下:
<?xml version="1.0" encoding="UTF-8"?> <web-app version="2.4" xmlns="http://java.sun.com/xml/ns/j2ee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd"> <servlet> <servlet-name>Hello</servlet-name> <servlet-class>example.Hello</servlet-class> </servlet> <servlet-mapping> <servlet-name>Hello</servlet-name> <url-pattern>*.do</url-pattern> </servlet-mapping> <welcome-file-list> <welcome-file>index.html</welcome-file> </welcome-file-list> </web-app>
6.在WebRoot下面新建引导页面index.html,代码如下:
<html> <head> <title>Hello FreeMarker Example</title> <meta http-equiv="Content-type" content="text/html; charset=utf-8"> </head> <body> 点击下面链接看看效果: <hr> <a href="hello.do">调用Hello模板</a> </body> </html>
7.把test项目部署到tomcate并启动服务。
8.打开浏览器,输入地址:http://localhost:8080/test/
9.点击调用Hello模板 链接,如果出现hello Csyor!则说明模板调用成功了!
FreeMarker 2.3.18 下载 和 API
FreeMarker 2.3.18 下载(密码:Pw7g)
以上内容来自于网络,如有侵权联系即删除。
猜你喜欢
发表评论
电子邮件地址不会被公开。 必填项已用*标注
评论信息
Csyor 2013-12-06 22:50
虽然本期的FreeMarker教程相对来说很简单,但是这只是入门,以后还会讲到标签的使用和静态页面的生成。