初建FreeMarker工程html
背景:據說freemarker能夠用來寫頁面的組件,熱衷於編寫可重用代碼的我,火燒眉毛地研究了freemarker,不過,在寫組件以前,仍是先研究一下freemarker的基本用法。html5
摘要:本文用了3種不一樣的方式(main、servlet、action),將freemarker融入工程之中。java
1、經過main方法使用freemarkerweb
1.新建一個普通的Java工程,在工程引入freemarker.jar,(右鍵-BuildPath(構建路徑)-ConfigureBuildPath(配置構建路徑) )。apache
2.在工程的根目錄下創建一個文件夾,命名爲templates(命名隨意),用來放freemarker的模板文件。tomcat
3.在templates下面新建一個模板文件,命名爲sample(命名隨意),後綴格式ftl(後綴隨意,通常是ftl),文件內容就寫一句簡單的:app
你好${username}
(之後經過這個模板文件,就能夠生成:你好張3、你好李4、你好王五。這個模板,看起來跟使用了struts2的JSP文件差很少,其實struts2原本就用了freemarker,struts2的基礎jar包裏就有freemarker.jar)ide
4.main方法以下:ui
public class Test { public static void main(String[] args) throws Exception { //讀取模板文件的所在目錄 Configuration configuration = new Configuration(); configuration.setDirectoryForTemplateLoading(new File("templates")); //讀取模板文件 Template template = configuration.getTemplate("sample.ftl"); //數據 Map<String, Object> map = new HashMap<String, Object>(); map.put("username", "lwp"); //輸出方式 Writer out = new OutputStreamWriter(System.out); //將模板轉換並輸出 template.process(map, out); //使用了流以後,記得要關掉 out.close(); } }
5.在控制檯看輸出結果爲:this
你好lwp
(體驗了簡單的,接着就試試高級一點的)
6.在templates下面新建一個模板文件header.ftl,內容以下:
<#macro show age="50"> ${username}-${age} </#macro> <#macro show2 age="50"> <#nested>-${age} </#macro>
7.修改sample.ftl,內容以下:
1.你好,${username} 2.你好,<#if username=="lwp">程序猿<#else>${username}</#if> 3.你好,${user.name} <#include "header.ftl"> 4.你好,<@show /> 5.你好,<@show age="12" /> 6.你好,<@show2>${username}</@show2> 7.你好,<@show2 age="12">${username}</@show2> <#import "header.ftl" as lwp> 8.你好,<@lwp.show /> 9.你好,<@lwp.show age="12" />
8.新建一個User類:
public class User implements Serializable { private static final long serialVersionUID = 1L; private String name; public User(String name) { this.name = name; } public String getName() { return name; } public void setName(String name) { this.name = name; } }
9.main方法改成這樣:(多了一句map.put("user", new User("userLWP"));)
public class Test { public static void main(String[] args) throws Exception { //讀取模板文件的所在目錄 Configuration configuration = new Configuration(); configuration.setDirectoryForTemplateLoading(new File("templates")); //讀取模板文件 Template template = configuration.getTemplate("sample.ftl"); //數據 Map<String, Object> map = new HashMap<String, Object>(); map.put("username", "lwp"); map.put("user", new User("userLWP")); //輸出方式 Writer out = new OutputStreamWriter(System.out); //將模板轉換並輸出 template.process(map, out); //使用了流以後,記得要關掉 out.close(); } }
10.在控制檯看結果:
1.你好,lwp 2.你好,程序猿 3.你好,userLWP 4.你好,lwp-50 5.你好,lwp-12 6.你好,lwp-50 7.你好,lwp-12 8.你好,lwp-50 9.你好,lwp-12
(效果甚好,我打算之後就用macro來寫組件了)
2、經過servlet使用freemarker
1.新建一個動態web工程,把freemarker.jar複製到WEB-INF的lib裏面,(若是不起做用,就用上面的方式引入freemarker.jar吧)。
2.在WebRoot或WebContent下面,創建一個文件夾,命名爲templates(命名隨意),用來放freemarker的模板文件。
3.在templates下面新建一個模板文件,命名爲sample(命名隨意),後綴格式ftl(後綴隨意,通常是ftl),文件內容以下:
(在servlet中,使用了response輸出爲網頁,因此模板內容按照html5的規範來寫,不能像上面那樣隨意了)
<!DOCTYPE html> <html> <head> <title>MyHtml.html</title> <meta charset="utf-8"> </head> <body> 1.你好,${username}<br> 2.你好,<#if username=="lwp">程序猿<#else>${username}</#if><br> 3.你好,${user.name}<br> <#include "header.ftl"> 4.你好,<@show /><br> 5.你好,<@show age="12" /><br> 6.你好,<@show2>${username}</@show2><br> 7.你好,<@show2 age="12">${username}</@show2><br> <#import "header.ftl" as lwp> 8.你好,<@lwp.show /><br> 9.你好,<@lwp.show age="12" /><br> </body> </html>
4.header.ftl專門被引用,跟以前的同樣就行:
<#macro show age="50"> ${username}-${age} </#macro> <#macro show2 age="50"> <#nested>-${age} </#macro>
5.複製剛纔的User類:
public class User implements Serializable { private static final long serialVersionUID = 1L; private String name; public User(String name) { this.name = name; } public String getName() { return name; } public void setName(String name) { this.name = name; } }
6.新建servlet類,內容以下:
public class TestServlet extends HttpServlet { private static final long serialVersionUID = 1L; @Override protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { try { this.execute(req, resp); } catch (Exception e) { e.printStackTrace(); } } @Override protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { try { this.execute(req, resp); } catch (Exception e) { e.printStackTrace(); } } public void execute(HttpServletRequest req, HttpServletResponse resp) throws Exception { //讀取模板文件的所在目錄 Configuration configuration = new Configuration(); configuration.setServletContextForTemplateLoading(super.getServletContext(), "templates"); configuration.setDefaultEncoding("utf-8"); //讀取模板文件 Template template = configuration.getTemplate("sample.ftl"); //數據 Map<String, Object> map = new HashMap<String, Object>(); map.put("username", "lwp"); map.put("user", new User("userLWP")); //輸出方式:response輸出 resp.setCharacterEncoding("utf-8"); Writer out = resp.getWriter(); //將模板轉換並輸出 template.process(map, out); //使用了流以後,記得要關掉 out.close(); } }
7.在web.xml配置一下servlet:
<?xml version="1.0" encoding="UTF-8"?> <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" id="WebApp_ID" version="3.0"> <!-- 項目名稱 --> <display-name>freemarker_servlet</display-name> <servlet> <!-- servlet的名稱(隨意) --> <servlet-name>TestServlet</servlet-name> <!-- servlet的所在路徑(按實際填寫) --> <servlet-class>lwp.TestServlet</servlet-class> </servlet> <servlet-mapping> <!-- servlet的名稱(跟上面同樣) --> <servlet-name>TestServlet</servlet-name> <!-- servlet的請求url --> <url-pattern>/TestServlet</url-pattern> </servlet-mapping> </web-app>
8.啓動一下tomcat,在地址欄輸入http://localhost:8080/freemarker_servlet/TestServlet
9.看到運行結果:
1.你好,lwp 2.你好,程序猿 3.你好,userLWP 4.你好,lwp-50 5.你好,lwp-12 6.你好,lwp-50 7.你好,lwp-12 8.你好,lwp-50 9.你好,lwp-12
(其實,自從接觸struts2以後,我已經很久沒用servlet了)
3、經過action使用freemarker
1.新建一個動態web工程,把struts2的基礎包複製到WEB-INF的lib下面。
(基礎包在struts-2.3.16.1\apps\struts2-blank.war,用解壓軟件打開以後,找到WEB-INF\lib,裏面那些包就是基礎包了,其中包括了freemarker-2.3.19.jar)。
2.在WebRoot或WebContent下面,創建一個文件夾,命名爲templates(命名隨意),用來放freemarker的模板文件。
3.在templates下面新建一個模板文件,命名爲sample(命名隨意),後綴格式ftl(後綴隨意,通常是ftl),文件內容以下:
(由於要輸出爲網頁,因此模板內容按照html5的規範來寫)
<!DOCTYPE html> <html> <head> <title>MyHtml.html</title> <meta charset="utf-8"> </head> <body> <#if user ?? || username ??> 1.你好,${username}<br> 2.你好,<#if username=="lwp">程序猿<#else>${username}</#if><br> 3.你好,${user.name}<br> <#include "header.ftl"> 4.你好,<@show /><br> 5.你好,<@show age="12" /><br> 6.你好,<@show2>${username}</@show2><br> 7.你好,<@show2 age="12">${username}</@show2><br> <#import "header.ftl" as lwp> 8.你好,<@lwp.show /><br> 9.你好,<@lwp.show age="12" /><br> </#if> </body> </html>
4.header.ftl專門被引用,跟以前的同樣就行:
<#macro show age="50"> ${username}-${age} </#macro> <#macro show2 age="50"> <#nested>-${age} </#macro>
5.複製以前的User類:
public class User implements Serializable { private static final long serialVersionUID = 1L; private String name; public User(String name) { this.name = name; } public String getName() { return name; } public void setName(String name) { this.name = name; } }
6.新建action,內容以下:
public class TestAction extends ActionSupport { private static final long serialVersionUID = 1L; private String username; private User user; @Override public String execute() throws Exception { //數據 this.username = "lwp"; this.user = new User("userLWP"); //返回 return ActionSupport.SUCCESS; } public String getUsername() { return username; } public void setUsername(String username) { this.username = username; } public User getUser() { return user; } public void setUser(User user) { this.user = user; } }
7.在struts.xml配置action:
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE struts PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 2.3//EN" "http://struts.apache.org/dtds/struts-2.3.dtd"> <struts> <package name="default" extends="struts-default"> <!-- action的請求名字 --> <action name="test" class="lwp.TestAction"> <result name="success" type="freemarker">/templates/sample.ftl</result> </action> <!-- ftl模板文件是不能直接輸出的,通過action以後才能轉化頁面顯示。如下這個配置是通過action的直接返回 --> <action name="*"> <result type="freemarker">/templates/{1}.ftl</result> </action> </package> </struts>
8.在web.xml配置struts:
<?xml version="1.0" encoding="UTF-8"?> <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" id="WebApp_ID" version="3.0"> <!-- 項目名稱 --> <display-name>freemarker_struts</display-name> <!-- struts2的配置 --> <filter> <filter-name>struts2</filter-name> <filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class> </filter> <filter-mapping> <filter-name>struts2</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> </web-app>
9.啓動一下tomcat,在地址欄輸入http://localhost:8080/freemarker_struts/test.action
10.看到運行結果:
1.你好,lwp 2.你好,程序猿 3.你好,userLWP 4.你好,lwp-50 5.你好,lwp-12 6.你好,lwp-50 7.你好,lwp-12 8.你好,lwp-50 9.你好,lwp-12