网页静态化技术 Freemarker
网页静态化解决方案在实际运用中比较多,例如新闻网站,门户网站中的新闻频道或者是文章类的频道。对于电商网站的商品详细页(几百万的商品,同样的页面模板格局)来说,每个商品又有大量的信息,这样的情况同样也适用于网页静态化解决方案。
网页静态化技术和缓存技术的共同点都是为了减轻数据库的访问压力,但是具体的应用场景不同,缓存比较适合小规模的数据,而网页静态化比较适合大规模且相对变化不大频繁的数据。另外网页静态化还有利于 SEO(搜索引擎优化)
另外我们如果将网页以纯静态化的形式展现,就可以使用 Nginx这样的高性能的 Web服务器来部署。Nginx可以承载5万的并发,而 Tomcat只有几百。
一、什么是 Freemarker
FreeMarker是一款模板引擎:即一种基于模板和要改变的数据, 并用来生成输出文本(HTML网页、电子邮件、配置文件、源代码等)的通用工具。 它不是面向最终用户的,而是一个 Java类库,是一款程序员可以嵌入他们所开发产品的组件。
FreeMarker最初的设计,是被用来在 MVC模式的 Web开发框架中生成 HTML页面的,没有被绑定到 Servlet或 HTML或任意 Web相关的东西上,它也可以用于非 Web应用环境中。
二、Freemarker 入门程序
【1】引入模板 Jar 包的依赖
1 <dependency>
2 <groupId>org.freemarker</groupId>
3 <artifactId>freemarker</artifactId>
4 <version>2.3.23</version>
5 </dependency>
【2】创建模板文件:在配置文件目录(/src/main/resources/)下创建 test.ftl (扩展名.ftl 没有强制的要求)
模板文件中四种元素:
● 文本:直接输出的部分
● 注释:即<#--...-->格式不会输出,<!-- -->注释会输入到页面。
● 插值(Interpolation):即${..}部分,将使用 数据模型 中的部分替代输出
● FTL指令:FreeMarker指令,和 HTML标记类似,名字前加#予以区分,不会输出。
1 <html>
2 <head>
3 <meta charset="utf-8">
4 <title>Freemarker入门小DEMO </title>
5 </head>
6 <body>
7 <#--我只是一个注释,我不会有任何输出 -->
8 ${name},你好。${message}
9 </body>
10 </html>
【3】Freemark 生成文件(将数据与模板进行关联)。主函数代码如下:
1 package com.itecast.demo;
2
3 import java.io.File;
4 import java.io.FileWriter;
5 import java.io.Writer;
6 import java.util.HashMap;
7 import java.util.Map;
8
9 import freemarker.template.Configuration;
10 import freemarker.template.Template;
11
12 public class FreemarkeDemo {
13 public static void main(String[] args) throws Exception {
14 //1、创建配置类:Configuration 对象 直接new 构造方法为 freemark 的版本
15 Configuration configuration = new Configuration(Configuration.getVersion());
16 //2、通过配置获取模板路径 需要处理异常 (注意 是正斜杠)
17 configuration.setDirectoryForTemplateLoading(new File("E:/learnWorkspaces/demo/freemarkDemo/src/main/resources/"));
18 //3、设置字符集
19 configuration.setDefaultEncoding("UTF-8");
20 //4、获取模板文件 创建一个模板文件(既返回对象)
21 Template template = configuration.getTemplate("test.ftl");
22 //5、创建一个模板使用的数据集,可以是 pojo 也可以是 map,一般是map
23 Map map=new HashMap();
24 map.put("name", "郑少");
25 map.put("message", "欢迎来到品优购世界!");
26 //6、创建输入对象 writer 对象
27 Writer out = new FileWriter(new File("D:\\test.html"));
28 //7、将模板 、 数据 、输出文件 进行关联 输出
29 template.process(map, out);
30 //8、关闭文件流
31 out.close();
32 }
33 }
【4】FTL 指令:assign 指令:用于在页面上定义一个变量
① 定义简单类型:linkname 为变量
1 <#assign linkname="银通">
2 公司名称:${linkname}
② 定义对象类型
1 <#assign info={"name":"王五","age":12}>
2 姓名:${info.name}
3 年龄:${info.age}
③ 运行效果如下:
include 指令:此指令用于模板文件的嵌套,创建嵌套文件 head.ftl
<#include "head.ftl">
if 指令:在模板文件中进行逻辑判断,后台构造 success 变量的数据。
map.put("success", true);
模板中添加 if 指令:
1 <#if success=true>
2 你已通过实名认证
3 <#else>
4 你未通过实名认证
5 </#if>
list 指令:循环实现列表的展示,后台构造 list 数据:
1 List goodsList=new ArrayList();
2 Map goods1=new HashMap();
3 goods1.put("name", "苹果");
4 goods1.put("price", 5.8);
5 Map goods2=new HashMap();
6 goods2.put("name", "香蕉");
7 goods2.put("price", 2.5);
8 Map goods3=new HashMap();
9 goods3.put("name", "橘子");
10 goods3.put("price", 3.2);
11 goodsList.add(goods1);
12 goodsList.add(goods2);
13 goodsList.add(goods3);
14 map.put("goodsList", goodsList);
模板中添加 list 指令: *_index 为freemaker的内置属性,用来获取下表,从0开始
1 <#list goodsList as goods>
2 序号:${goods_index+1} <!--*_index 为freemaker的内置属性,用来获取下表,从0开始-->
3 名称:${goods.name}
4 价格:${goods.price}
5 </#list>
【5】内建函数:函数的语法:变量+?+函数名称
① 使用 size 函数实现 list 的长度:
一共${goodsList?size}条记录
② 转换 JSON 字符串为对象:变量=字符串+?+eval
1 <#assign text="{'bank':'工商银行','account':'10101920201920212'}"/>
2 <#assign data=text?eval/>
3 开户行:${data.bank} 账号:${data.account}
③ 日期格式转化:变量+?+date 后台数据构建如下:
map.put("today", new Date());
模板中获取日期、时间、日期时间组合和日期的格式转化,如下:
1 当前日期:${today?date} <br>
2 当前时间:${today?time} <br>
3 当前日期+时间:${today?datetime} <br>
4 日期格式化: ${today?string("yyyy年MM月")}
④ 数字转化为字符串(模板默认将数字进行了分割符切分),后台数据组装
map.put("point", 102920122);
模板中直接展示:
累计积分:${point}
效果如下:我们会发现数字会以每三位一个分隔符显示,有些时候我们不需要这个分隔符,就需要将数字转换为字符串,使用内建函数c:${point?c}
三、空值处理运算符
如果你在模板中使用了变量但是在代码中没有对变量赋值,那么运行生成时会抛出异常。但是有些时候,有的变量确实是null,怎么解决这个问题呢?
【1】缺失变量赋值:“!”(我们除了可以判断是否为空值,也可以使用!对null值做转换处理)
<#--在代码中不对aaa赋值,也不会报错了 ,当aaa为null则返回!后边的内容-->
${aaa!'-'}
【2】用法为:variable??,如果该变量存在,返回true,否则返回false
1 <#if aaa??>
2 aaa变量存在
3 <#else>
4 aaa变量不存在
5 </#if>
四、运算符
● 算数运算符
FreeMarker表达式中完全支持算术运算,FreeMarker支持的算术运算符包括:+, - , * , / , %
●逻辑运算符:逻辑运算符有如下几个:
逻辑与:&&
逻辑或:||
逻辑非:!
逻辑运算符只能作用于布尔值,否则将产生错误
● 比较运算符:表达式中支持的比较运算符有如下几个:
=或者==:判断两个值是否相等.
!=:判断两个值是否不等.
>或者gt:判断左边值是否大于右边值
>=或者gte:判断左边值是否大于等于右边值
<或者lt:判断左边值是否小于右边值
<=或者lte:判断左边值是否小于等于右边值
注意: =和!=可以用于比较字符串,数值和日期是否相等,但=和!=两边必须是相同类型的值,否则会产生错误,而且FreeMarker是精确比较,"x","X"是不等的。其它的运行符可以作用于数字和日期,但不能作用于字符串,大部分的时候,使用gt等字母运算符代替 > 会有更好的效果,因为 FreeMarker会把 > 解释成 FTL 标签的结束字符,当然,也可以使用括号来避免这种情况,如:<#if (x>y)>
五、项目实战(spring 配置文件中注入FreeMarkerConfigurer 并配置模板的存放位置)
1 <bean id="freemarkerConfig" class="org.springframework.web.servlet.view.freemarker.FreeMarkerConfigurer">
2 <property name="templateLoaderPath" value="/WEB-INF/ftl/" />
3 <property name="defaultEncoding" value="UTF-8" />
4 </bean>
网页静态化技术 Freemarker的更多相关文章
- 网页静态化技术Freemarker的详细介绍
网页静态化技术Freemarker 一.Freemarker的基本介绍 1.1为什么要使用网页静态化技术 网页静态化解决方案在实际开发中运用比较多,例如新闻网站,门户网站中的新闻频道或者是文章类的频道 ...
- 网页静态化技术--Freemarker入门
网页静态化技术:为什么要使用网页静态化技术 网页静态化解决方案在实际开发中运用比较多,例如新闻网站,门户网站中的新闻频道或者是文章类的频道. 对于电商网站的商品详细页来说,至少几百万个商品,每个商品又 ...
- 网页静态化技术Freemarker
1.为什么要使用网页静态化技术 网页静态化解决方案在实际开发中运用比较多,例如新闻网站,门户网站中的新闻频道或者是文章类的频道. 对于电商网站的商品详细页来说,至少几百万个商品,每个商品又有大量的信息 ...
- 网页静态化解决方案-Freemarker demo+语法
1.网页静态化技术Freemarker 1.1为什么要使用网页静态化技术 网页静态化解决方案在实际开发中运用比较多,例如新闻网站,门户网站中的新闻频道或者是文章类的频道. 对于电商网站的商品详细页来说 ...
- 网页静态化技术Freemarkerh简介
1.1为什么要使用网页静态化技术 网页静态化解决方案在实际开发中运用比较多,例如新闻网站,门户网站中的新闻频道或者是文章类的频道. 对于电商网站的商品详细页来说,至少几百万个商品,每个商品又有大量的信 ...
- 网页静态化—redis | freemarker
1. 学习计划 1.商品详情页面展示,动态展示 jsp + redis 2.使用freemarker实现网页静态化 3.ActiveMq同步生成静态网页 两个方案对比,方案一依赖web容器,red ...
- 网页静态化解决方案Freemarker
序言: 沉淀了三个月,逐步将自己最近两年在公司中用到的技术和知识点,重新整理归纳了下,对比以前可以发现,现在技术更新越来越快,也越来越成熟,在互联网企业,用到的技术也更先进,更领先,比如微服务.分布式 ...
- 页面静态化技术Freemarker技术的介绍及使用实例.
一.FreeMarker简介 1.动态网页和静态网页差异 在进入主题之前我先介绍一下什么是动态网页,动态网页是指跟静态网页相对应的一种网页编程技术.静态网页,随着HTML代码的生成,页面的内容和显示效 ...
- 网页静态化解决方案-Freemarker
1.1 技术简介与使用 1.1.1 简介 为什么使用: 1. 减轻数据库的访问压力,静态化比较适合大规模且相对变化不太频繁的数据: 2. 有利于SEO(搜索引擎优化); 纯的HTML ...
- 静态化技术Freemarker
什么是Freemarker FreeMarker是一个用Java语言编写的模板引擎,它基于模板来生成文本输出.FreeMarker与Web容器无关,即在Web运行时,它并不知道Servlet或HTTP ...
随机推荐
- C#之List、Queue、Stack使用EnsureCapacity方法预设数组大小
简介 List.Queue 和 Stack 集合中的 EnsureCapacity方法预设数组大小. 为什么以及何时使用EnsureCapacity 方法 这里我们将首先了解为什么需要使用这种方法以及 ...
- 数据库负载均衡 happroxy 中间器(Nginx)容器的安装与配置
docker 镜像中安装haproxy 1.下载并安装haproxy镜像 docker pull happroxy # docker pull haproxy:1.7 2.查看镜像 docker i ...
- ssh scp 相关
1. 设置ssh 的免密登录 1> 将 ~/.ssh/id_rsa.pub文件中的内容拷贝到 远程host的 ~/.ssh/authorized_keys文件中 2> ssh-copy-i ...
- elasticsearch 根据主键_id更新部分字段
package com.better517na.ebookingbusiservice.helper;import com.alibaba.fastjson.JSON;import com.aliba ...
- Email Windows发送成功,Linux却发送失败的可能原因
一.linux端口被禁用,通过telnet查看.(我这里没问题) 二.排查环境参数是否一致(我这里没问题) 三.查看jdk版本原因,因为jdk1.8有的版本禁用了ssl 参阅文档:https://bl ...
- #AI 绘图 #GitHub GitHub上这几个项目教你怎么用,让你成为神笔马良
1.前情提要 前两天在 GitHub Trending 上看到个利用 AI 自动给图片上色的项目(style2paints)火起来了. 在 AI 大行其道的时代,工程师们也开始思考如何用这项技术来解决 ...
- 测试Lock锁
package com.company;import java.util.concurrent.locks.ReentrantLock;//测试Lock锁public class TestLock i ...
- node.js 数据模拟
Node: js在服务端的一个运行环境 node框架:express koa egg (本文采用express) express: 是基于node的一个web框架 restful api:是目前流 ...
- CentOS7安装 Redis5 单实例
1.下载redis下载地址在:redis.io比如把Redis安装到/usr/local/soft/ cd /usr/local/soft/ wget http://download.redis.io ...
- 量化交易基础-ICIR
IC - information coefficient r=1.5+a1+a2+...+a81 ai={-1,1}随机序列 ()收益序列 E(r)=1.5 期望 cov(r)=81 协方差 std( ...