FreeMarker在Web应用中的配置

一、FreeMarker介绍:

FreeMarker是一个用Java语言编写的模板引擎,它基于模板来生成文本输出。FreeMarker与Web容器无关,即在Web运行时,它并不知道Servlet或HTTP。它不仅可以用作表现层的实现技术,而且还可以用于生成XML,JSP或Java 等。

优点:

FreeMarker允许Java servlet保持图形设计应用程序逻辑的分离,

这是通过在模板中密封HTML完成的。模板servlet提供的数据动态地生成 HTML。

模板语言是强大的直观的,编译器速度快,输出接近静态HTML页面的速度。

虽然FreeMarker具有一些编程的能力,但通常由Java程序准备要显示的数据,

由FreeMarker生成页面,通过模板显示准备的数据。

通用数据模型

FreeMarker不是直接反射到Java对象,Java对象通过插件式对象封装,以变量方式在模板中显示。

可以使用抽象(接口)方式表示对象(JavaBeanXML文档、SQL查询结果集等等),

告诉模板开发者使用。方法,使其不受技术细节的打扰。

为Web准备

在模板语言中内建处理典型Web相关任务(如HTML转义)的结构。

能够集成到Model2 Web应用框架中作为JSP的替代。

支持JSP标记库。

为MVC模式设计:分离可视化设计和应用程序逻辑;分离页面设计员和程序员。

二、在 web中的配置:

1、创建一个动态的web项目FreeMarkerTest,并在lib中加入freemarker的jar 包

2、web.xml配置:

<?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">


	<welcome-file-list>
		<welcome-file>index.jsp</welcome-file>
	</welcome-file-list>

	<servlet>
		<servlet-name>freemarker</servlet-name>
		<servlet-class>freemarker.ext.servlet.FreemarkerServlet</servlet-class>
		<!-- FreemarkerServlet settings: -->
		<init-param>
			<param-name>TemplatePath</param-name>
			<param-value>/</param-value>
		</init-param>
		
		<init-param>
			<param-name>NoCache</param-name>
			<param-value>true</param-value>
		</init-param>
		
		<init-param>
			<param-name>ContentType</param-name>
			<param-value>text/html</param-value>
		</init-param>

		<init-param>
			<param-name>template_update_delay</param-name>
			<param-value>0</param-value>
			<!-- 0 is for development only! Use higher value otherwise. -->
		</init-param>
		
		<init-param>
			<param-name>locale</param-name>
			<param-value>zh_CN</param-value>
		</init-param>
		
		<init-param>
			<param-name>default_encoding</param-name>
			<param-value>UTF-8</param-value>
		</init-param>
		
		<init-param>
			<param-name>boolean_format</param-name>
			<param-value>true,false</param-value>
		</init-param>
		
		<init-param>
			<param-name>datetime_format</param-name>
			<param-value>yyyy-MM-dd HH:mm:ss</param-value>
		</init-param>
		
		<init-param>
			<param-name>date_format</param-name>
			<param-value>yyyy-MM-dd</param-value>
		</init-param>
		
		<init-param>
			<param-name>time_format</param-name>
			<param-value>HH:mm:ss</param-value>
		</init-param>
		
	    <init-param>
			<param-name>number_format</param-name>
			<param-value>0.##########</param-value>
		</init-param>
		<!--自动导入模板 标签为p-->
		<init-param>
			<param-name>auto_import</param-name>
			<param-value>/ftl/test.ftl as p</param-value>
		</init-param>
		
	</servlet>

	<!-- freemarker-->
	<servlet-mapping>
		<servlet-name>freemarker</servlet-name>
		<url-pattern>*.html</url-pattern>
	</servlet-mapping>
</web-app>

3、在WebRoot 下创建一个模板文件  /ftl/test.ftl

<#macro m1>   <#--定义指令m1 -->
	<b>aaabbbccc</b>
	<b>dddeeefff</b>
</#macro>

4、index.html 中引用:

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
    <title>index.html</title>
    <meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
    <meta http-equiv="description" content="this is my page">
    <meta http-equiv="content-type" content="text/html; charset=UTF-8">
    
    <!--<link rel="stylesheet" type="text/css" href="./styles.css">-->

  </head>
  
  <body>
  	
    This is my HTML page. <br>
    <!-- 引用模板标签 -->
    <@p.m1 />
  </body>
</html>

5,启动服务访问:http://localhost:8080/FreeMarkerTest/index.html

显示:

This is my HTML page. 
aaabbbccc dddeeefff


郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。