freemarket 对象应用篇(一)

freemarket应用.
1.1:创建web工程testFM
1.2:下载从官方下载freemarker的包,下载地址:
http://freemarker.sourceforge.net/freemarkerdownload.html(这里使用2.3.x)

         1.3:把freemarker-2.3.15.jar导入到web工程中。
1.4:在WebRoot目录之下创建templates目录(专门存储模板)
1.5:在templates目录之下,创建hello.ftl模板。具体代码如下:
  
<html>
<head>
<title>hello!</title>
</head>
<body>
<!-- User 对象 -->
<h1>hello ${lastProduct.name}!</h1>
<!-- List 对象 -->
<#list userList as user>
	<h1>Welcome ${user.name}&nbsp;&nbsp;id:${user.id}</h1><br/>
</#list>
</body>
</html>

         1.6:创建一个servlet,名为Hello。代码如下:
package example;

import java.io.IOException;
import java.io.PrintWriter;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
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;

public class Hello extends HttpServlet {

	/**
	 * Destruction of the servlet. <br>
	 */
	public void destroy() {
		super.destroy(); // Just puts "destroy" string in log
		// Put your code here
	}

	public void doGet(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {

		//建立数据模型
		Map root = new HashMap();	
		/***** 对象应用 start *****/
		User product = new User();
		root.put("lastProduct", product);
		product.setId("123");
		product.setName("张三");
		/***** 对象应用 end *****/
		/***** List对象应用 start *****/
		List<User> users = new ArrayList<User>();
		User u1 = new User();
		u1.setId("123");
		u1.setName("王五");
		User u2 = new User();
		u2.setId("456");
		u2.setName("张三");
		User u3 = new User();
		u3.setId("789");
		u3.setName("李四");
		users.add(u1);
		users.add(u2);
		users.add(u3);
		root.put("userList", users);
		/***** List对象应用 end *****/
		//取得模版文件
		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);
		}
		
	}
	
	private Configuration cfg;

	public void init() throws ServletException {
		// Put your code here
		//初始化FreeMarker配置
		//创建一个Configuration实例
		cfg = new Configuration();
		//设置FreeMarker的模版文件位置
		cfg.setServletContextForTemplateLoading(getServletContext(),"templates");
	}

}

1.7:修改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>
    <description>This is the description of my J2EE component</description>
    <display-name>This is the display name of my J2EE component</display-name>
    <servlet-name>Hello</servlet-name>
    <servlet-class>example.Hello</servlet-class>
  </servlet>

  <servlet-mapping>
    <servlet-name>Hello</servlet-name>
    <url-pattern>*.do</url-pattern> <!-- 修改成*.do -->
  </servlet-mapping>
  <welcome-file-list>
    <welcome-file>index.jsp</welcome-file>
  </welcome-file-list>
</web-app>

1.8:创建index.jsp。并在body标签填写如下代码:
     
点击下面链接看看效果:<hr><a href="hello.do">调用Hello模板</a>

         1.9:启动web服务器。在浏览器中输入地址。如:
             
http://localhost:8080/testFM/index.jsp

         1.10:结果为
hello 张三!

你可能感兴趣的:(freemarker)