SpringBoot2 整合FreeMarker模板,完成页面静态化处理

本文涉及的产品
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
云解析 DNS,旗舰版 1个月
全局流量管理 GTM,标准版 1个月
简介: 即静态网页,指已经装载好内容HTML页面,无需经过请求服务器数据和编译过程,直接加载到客户浏览器上显示出来。通俗的说就是生成独立的HTML页面,且不与服务器进行数据交互。


一、页面静态化


1、动静态页面


静态页面


即静态网页,指已经装载好内容HTML页面,无需经过请求服务器数据和编译过程,直接加载到客户浏览器上显示出来。通俗的说就是生成独立的HTML页面,且不与服务器进行数据交互。


优缺点描述:



  • 静态网页的内容稳定,页面加载速度极快;
  • 不与服务器交互,提升安全性;
  • 静态网页的交互性差,数据实时性很低;
  • 维度成本高,生成很多HTML页面;

动态页面


指跟静态网页相对的一种网页编程技术,页面的内容需要请求服务器获取,在不考虑缓存的情况下,服务接口的数据变化,页面加载的内容也会实时变化,显示的内容却是随着数据库操作的结果而动态改变的。


优缺点描述:



  • 动态网页的实时获取数据,延迟性低;
  • 依赖数据库交互,页面维护成本很低;
  • 与数据库实时交互,安全控制的成本高;
  • 页面加载速度十分依赖数据库和服务的性能;

动态页面和静态页面有很强的相对性,对比之下也比较好理解。


2、应用场景


动态页面静态化处理的应用场景非常多,例如:



  • 大型网站的头部和底部,静态化之后统一加载;
  • 媒体网站,内容经过渲染,直接转为HTML网页;
  • 高并发下,CDN边缘节点代理的静态网页;
  • 电商网站中,复杂的产品详情页处理;

静态化技术的根本:提示服务的响应速度,或者说使响应节点提前,如一般的流程,页面(客户端)请求服务,服务处理,响应数据,页面装载,一系列流程走下来不仅复杂,而且耗时,如果基于静态化技术处理之后,直接加载静态页面,好了请求结束。


二、流程分析


静态页面转换是一个相对复杂的过程,其中核心流程如下:


23-1.png



  • 开发一个页面模板,即静态网页样式;
  • 提供接口,给页面模板获取数据;
  • 页面模板中编写数据接口返参的解析流程;
  • 基于解析引擎,把数据和页面模板合并;
  • 页面模板内容加载完成后转换为HTML静态页面;
  • HTML静态页面上传到文件服务器;
  • 客户端(Client)获取静态页面的url加载显示;

主流程大致如上,如果数据接口响应参数有变,则需要重新生成静态页,所以在数据的加载实时性上面会低很多。


三、代码实现案例


1、基础依赖


FreeMarker是一款模板引擎:即一种基于模板和要改变的数据,并用来生成输出文本(HTML网页、电子邮件、配置文件、源代码等)的通用工具。


<dependency>
&lt;groupId&gt;org.springframework.boot&lt;/groupId&gt;
&lt;artifactId&gt;spring-boot-starter-freemarker&lt;/artifactId&gt;

</dependency>


2、页面模板


这里既使用FreeMarker开发的模板样式。


<html>
<head>
&lt;title&gt;PageStatic&lt;/title&gt;

</head>
<body>
主题:${myTitle}<br/>
<#assign text="{'auth':'cicada','date':'2020-07-16'}" />
<#assign data=text?eval />
作者:${data.auth} 日期:${data.date}<br/>
<table class="table table-striped table-hover table-bordered" id="editable-sample">

&lt;thead&gt;
&lt;tr&gt;
    &lt;th&gt;规格描述&lt;/th&gt;
    &lt;th&gt;产品详情&lt;/th&gt;
&lt;/tr&gt;
&lt;/thead&gt;
&lt;tbody&gt;
         &lt;#list tableList as info&gt;
         &lt;tr class=""&gt;
             &lt;td&gt;${info.desc}&lt;/td&gt;
             &lt;td&gt;&lt;img src="${info.imgUrl}" height="80" width="80"&gt;&lt;/td&gt;
         &lt;/tr&gt;
         &lt;/#list&gt;
&lt;/tbody&gt;

</table><br/>
<#list imgList as imgIF>

&lt;img src="${imgIF}" height="300" width="500"&gt;

</#list>
</body>
</html>


FreeMarker的语法和原有的HTML语法基本一致,但是具有一套自己的数据处理标签,用起来不算复杂。


3、解析过程


通过解析,把页面模板和数据接口的数据合并到一起即可。


@Service
public class PageServiceImpl implements PageService {
private static final Logger LOGGER = LoggerFactory.getLogger(PageServiceImpl.class) ;
private static final String PATH = "/templates/" ;

@Override
public void ftlToHtml() throws Exception {
    // 创建配置类
    Configuration configuration = new Configuration(Configuration.getVersion());
    // 设置模板路径
    String classpath = this.getClass().getResource("/").getPath();
    configuration.setDirectoryForTemplateLoading(new File(classpath + PATH));
    // 加载模板
    Template template = configuration.getTemplate("my-page.ftl");
    // 数据模型
    Map&lt;String, Object&gt; map = new HashMap&lt;&gt;();
    map.put("myTitle", "页面静态化(PageStatic)");
    map.put("tableList",getList()) ;
    map.put("imgList",getImgList()) ;
    // 静态化页面内容
    String content = FreeMarkerTemplateUtils.processTemplateIntoString(template, map);
    LOGGER.info("content:{}",content);
    InputStream inputStream = IOUtils.toInputStream(content,"UTF-8");
    // 输出文件
    FileOutputStream fileOutputStream = new FileOutputStream(new File("F:/page/newPage.html"));
    IOUtils.copy(inputStream, fileOutputStream);
    // 关闭流
    inputStream.close();
    fileOutputStream.close();
}

private List&lt;TableInfo&gt; getList (){
    List&lt;TableInfo&gt; tableInfoList = new ArrayList&lt;&gt;() ;
    tableInfoList.add(new TableInfo(Constant.desc1, Constant.img01));
    tableInfoList.add(new TableInfo(Constant.desc2,Constant.img02));
    return tableInfoList ;
}

private List&lt;String&gt; getImgList (){
    List&lt;String&gt; imgList = new ArrayList&lt;&gt;() ;
    imgList.add(Constant.img02) ;
    imgList.add(Constant.img02) ;
    return imgList ;
}

}


生成后的HTML页面直接使用浏览器打开即可,不再需要依赖任何数据接口服务。


四、源代码地址


GitHub·地址
https://github.com/cicadasmile/middle-ware-parent
GitEE·地址
https://gitee.com/cicadasmile/middle-ware-parent

目录
相关文章
|
Java Maven
springboot项目--freemarker使用ftl模板文件动态生成图片
springboot项目--freemarker使用ftl模板文件动态生成图片
811 0
|
前端开发 Java
SpringBoot-6-模板Thymeleaf常用标签
SpringBoot-6-模板Thymeleaf常用标签
92 0
SpringBoot-6-模板Thymeleaf常用标签
|
7月前
|
Java
Springboot视图解析与模板引擎~
Springboot视图解析与模板引擎~
|
7月前
|
Java
SpringBoot thymeleaf自定义错误页面
SpringBoot thymeleaf自定义错误页面
65 0
|
7月前
|
移动开发 运维 前端开发
SpringBoot 整合 Thymeleaf & 如何使用后台模板快速搭建项目
SpringBoot 整合 Thymeleaf & 如何使用后台模板快速搭建项目
125 0
|
XML 移动开发 前端开发
SpringBoot-5-页面展示Thymeleaf
SpringBoot-5-页面展示Thymeleaf
127 0
|
前端开发 JavaScript Java
前端|如何在SpringBoot中通过thymeleaf模板访问页面
前端|如何在SpringBoot中通过thymeleaf模板访问页面
339 0
|
前端开发 Java 开发者
【SpringBoot学习笔记 九】SpringBoot定制整合Thymeleaf及页面国际化(下)
【SpringBoot学习笔记 九】SpringBoot定制整合Thymeleaf及页面国际化(下)
172 0
|
移动开发 前端开发 JavaScript
【SpringBoot学习笔记 九】SpringBoot定制整合Thymeleaf及页面国际化
【SpringBoot学习笔记 九】SpringBoot定制整合Thymeleaf及页面国际化
113 0
|
消息中间件 JSON 前端开发
SpringBoot2.x系列教程08--SpringBoot中整合Thymeleaf动态模板
前言 在前面的章节中,壹哥 带各位利用SpringBoot实现了SSM整合,发现现在SSM整合变得的非常简单,通过几个配置就能搭建出一个项目开发环境。但是在之前的案例中,我们并没有提供UI界面,那么在SpringBoot中如何整合UI界面呢?使用JSP展示页面,还是用HTML展示页面,或者还有其他方案? 在今天的内容里,壹哥 会带大家学习如何在SpringBoot中展示UI界面,这样大家以后就可以把数据信息在页面上渲染展示了。 一. Web开发方式简介 SpringBoot作为一个简化项目开发的利器,其实它为我们提供了一套完整的Web开发方案,从前端到后端,再到数据库、定时任务、消息队列等都
301 0