天天看點

頁面靜态化freemarker詳解及實戰

為啥要網頁靜态化

①:網頁靜态化解決方案在實際開發中運用比較多,例如新聞網站,門戶網站中的新聞頻道或者是文章類的頻道。

對于電商網站的商品詳細頁來說,至少幾百萬個商品,每個商品又有大量的資訊,這樣的情況同樣也适用于使用網頁靜态化來解決。

②:網頁靜态化技術和緩存技術的共同點都是為了減輕資料庫的通路壓力,但是具體的應用場景不同,緩存比較适合小規模的資料,而網頁靜态化比較适合大規模且相對變化不太頻繁的資料。另外網頁靜态化還有利于SEO。

另外我們如果将網頁以純靜态化的形式展現,就可以使用Nginx這樣的高性能的web伺服器來部署。Nginx可以承載5萬的并發,而Tomcat隻有幾百。

Freemarker入門知識

Test.ftl

<#--我隻是一個注釋,我不會有任何輸出  -->
${name},你好。${message}

<h3>assigne指令</h3>
<#assign linkman="周先生">
聯系人:${linkman}

<#assign info={"mobile":"13301231212",'address':'北京市昌平區王府街'} >
電話:${info.mobile}  位址:${info.address}

<h3>if指令</h3>
<#if success=true>
  你已認證實名認證
<#else>  
  你未通過實名認證
</#if>

<h3>list指令</h3>
----商品價格表----<br>
<#list goodsList as goods>
  ${goods_index+1} 商品名稱: ${goods.name} 價格:${goods.price}<br>
</#list>

<h3>内建函數</h3>
<h4>擷取集合大小</h4>
共  ${goodsList?size}  條記錄

<h4>轉換JSON字元串為對象</h4>
    <#assign text="{'bank':'工商銀行','account':'10101920201920212'}" />
	<#assign data=text?eval />
	開戶行:${data.bank}  賬号:${data.account}
	
<h4>日期格式化</h4>
目前日期:${today?date} <br>
目前時間:${today?time} <br>   
目前日期+時間:${today?datetime} <br>        
日期格式化:  ${today?string("yyyy年MM月")}

<h4>數字轉換為字元串</h4>
累計積分:${point}
累計積分:${point?c}


<h3>空值處理運算符</h3>
<h4>判斷某變量是否存在:“??”</h4>
<#if aaa??>
  aaa變量存在
<#else>
  aaa變量不存在
</#if>

<h4>缺失變量預設值:“!”</h4>
  ${aaa!'-'}


<h3>運算符</h3>
<h4>算數運算符</h4>
FreeMarker表達式中完全支援算術運算,FreeMarker支援的算術運算符包括:+, - , * , / , %

<h4>邏輯運算符</h4>
邏輯運算符有如下幾個: 
邏輯與:&& 
邏輯或:|| 
邏輯非:! 
邏輯運算符隻能作用于布爾值,否則将産生錯誤 

<h4>比較運算符</h4>
表達式中支援的比較運算符有如下幾個: 
1  =或者==:判斷兩個值是否相等. 
2  !=:判斷兩個值是否不等. 
3  >或者gt:判斷左邊值是否大于右邊值 
4  >=或者gte:判斷左邊值是否大于等于右邊值 
5  <或者lt:判斷左邊值是否小于右邊值 
6  <=或者lte:判斷左邊值是否小于等于右邊值 
注意:  =和!=可以用于字元串,數值和日期來比較是否相等,但=和!=兩邊必須是相同類型的值,否則會産生錯誤,而且FreeMarker是精确比較,"x","x ","X"是不等的.其它的運作符可以作用于數字和日期,但不能作用于字元串,大部分的時候,使用gt等字母運算符代替>會有更好的效果,因為 FreeMarker會把>解釋成FTL标簽的結束字元,當然,也可以使用括号來避免這種情況,
           

背景類

package com.javaxl.freemarker;
import java.io.File;
import java.io.FileWriter;
import java.io.IOException;
import java.io.Writer;
import java.util.ArrayList;
import java.util.Date;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

import freemarker.template.Configuration;
import freemarker.template.Template;
import freemarker.template.TemplateException;

public class Demo001 {
	public static void main(String[] args) throws IOException, TemplateException {
		// 1.建立配置類
		Configuration configuration = new Configuration(Configuration.getVersion());
		// 2.設定模闆所在的目錄
		configuration.setDirectoryForTemplateLoading(
				new File("D:\\Y2homework\\homework\\javaxl_lunece_freemarker\\src\\main\\resources"));
		// 3.設定字元集
		configuration.setDefaultEncoding("utf-8");
		// 4.加載模闆
		Template template = configuration.getTemplate("test.ftl");
		// 5.建立資料模型
		Map map = new HashMap();
		map.put("name", "小李飛刀 ");
		map.put("message", "歡迎來到神奇的部落格網站:http://www.javaxl.com!");
		map.put("success", true);
		
		List goodsList=new ArrayList();
		Map goods1=new HashMap();
		goods1.put("name", "蘋果");
		goods1.put("price", 5.8);
		Map goods2=new HashMap();
		goods2.put("name", "香蕉");
		goods2.put("price", 2.5);
		Map goods3=new HashMap();
		goods3.put("name", "橘子");
		goods3.put("price", 3.2);
		goodsList.add(goods1);
		goodsList.add(goods2);
		goodsList.add(goods3);
		map.put("goodsList", goodsList);
		
		map.put("today", new Date());
		map.put("point", 102920122);
		
		// 6.建立Writer對象
		Writer out = new FileWriter(new File("D:\\Y2homework\\homework\\javaxl_lunece_freemarker\\src\\main\\webapp\\freemarker\\test.html"));
		// 7.輸出
		template.process(map, out);
		// 8.關閉Writer對象
		out.close();
	}
}
           

結果圖

頁面靜态化freemarker詳解及實戰

将網頁靜态化用于部落格網站

blogDetail.ftl

<div class="data_list">
	<div class="data_list_title">
		<img src="../blog_show_icon.png"/>
		部落格資訊
	</div>
	<div>
		<div class="blog_title"><h3><strong>${blog.title }</strong></h3></div>
		<div class="blog_share">
			<!-- <div class="bshare-custom"><a title="分享到QQ空間" class="bshare-qzone"></a><a title="分享到新浪微網誌" class="bshare-sinaminiblog"></a><a title="分享到人人網" class="bshare-renren"></a><a title="分享到騰訊微網誌" class="bshare-qqmb"></a><a title="分享到網易微網誌" class="bshare-neteasemb"></a><a title="更多平台" class="bshare-more bshare-more-icon more-style-addthis"></a><span class="BSHARE_COUNT bshare-share-count">0</span></div><script type="text/javascript" charset="utf-8" src="http://static.bshare.cn/b/buttonLite.js#style=-1&uuid=&pophcol=2&></script><script type="text/javascript" charset="utf-8" src="http://static.bshare.cn/b/bshareC0.js"></script> -->
		</div>
		<div class="blog_info">
			釋出時間:『${blog.releaseDate?datetime }』  部落格類别:${blog.btid }  閱讀(${blog.clickHit })
		</div>
		<div class="blog_content">
		${blog.content }
		</div>
	</div>
</div>
           

背景代碼

package com.javaxl.freemarker;
import java.io.File;
import java.io.FileWriter;
import java.io.IOException;
import java.io.Writer;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.HashMap;
import java.util.Map;

import com.javaxl.blog.util.DBAccess;

import freemarker.template.Configuration;
import freemarker.template.Template;
import freemarker.template.TemplateException;

public class Demo002 {
	@SuppressWarnings("rawtypes")
	public static void main(String[] args) throws IOException, TemplateException, SQLException {
		// 1.建立配置類
		Configuration configuration = new Configuration(Configuration.getVersion());
		// 2.設定模闆所在的目錄
		configuration.setDirectoryForTemplateLoading(
				new File("D:\\Y2homework\\homework\\javaxl_lunece_freemarker\\src\\main\\webapp\\freemarker"));
		// 3.設定字元集
		configuration.setDefaultEncoding("utf-8");
		// 4.加載模闆
		Template template = configuration.getTemplate("blogDetail.ftl");
		
		
		// 5.建立資料模型
//		Map map = new HashMap();
//		map.put("name", "小李飛刀 ");
//		// 6.建立Writer對象
//		Writer out = new FileWriter(new File("E:\\temp\\staticPage\\test.html"));
//		// 7.輸出
//		template.process(map, out);
		// 8.關閉Writer對象
//		out.close();
		createPage(template);
		
	}
	
	private static void createPage(Template template) throws SQLException, IOException, TemplateException {
		Connection con = DBAccess.getConnection();
		String sql = "select * from t_lucene_freemarker_blog";
		PreparedStatement pst = con.prepareStatement(sql);
		ResultSet rs = pst.executeQuery();
		Map map = new HashMap<>();
		Map<String, Object> blog = new HashMap<>();
		while(rs.next()) {
			blog.put("bid", rs.getObject("bid"));
			blog.put("title", rs.getObject("title"));
			blog.put("releaseDate", rs.getObject("releaseDate"));
			blog.put("btid", rs.getObject("btid"));
			blog.put("clickHit", rs.getObject("clickHit"));
			blog.put("content", rs.getObject("content"));
			
			map.put("blog", blog);
//			// 6.建立Writer對象
			Writer out = new FileWriter(new File("D:\\Y2homework\\homework\\javaxl_lunece_freemarker\\src\\main\\webapp\\freemarker\\"+blog.get("bid")+".html"));
			// 7.輸出
			template.process(map, out);
			// 8.關閉Writer對象
			out.close();
		}
		DBAccess.close(con, pst, rs);
	}
}
           

結果圖:

頁面靜态化freemarker詳解及實戰
頁面靜态化freemarker詳解及實戰
頁面靜态化freemarker詳解及實戰
頁面靜态化freemarker詳解及實戰
頁面靜态化freemarker詳解及實戰