SpringBoot2中如何使用FreeMarker模板完成页面静态化处理(freemarker,springboot,编程语言)

时间:2024-05-01 22:22:44 作者 : 石家庄SEO 分类 : 编程语言
  • TAG :

一、页面静态化

1、动静态页面

静态页面

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

优缺点描述:

  • 静态网页的内容稳定,页面加载速度极快;

  • 不与服务器交互,提升安全性;

  • 静态网页的交互性差,数据实时性很低;

  • 维度成本高,生成很多HTML页面;

动态页面

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

优缺点描述:

  • 动态网页的实时获取数据,延迟性低;

  • 依赖数据库交互,页面维护成本很低;

  • 与数据库实时交互,安全控制的成本高;

  • 页面加载速度十分依赖数据库和服务的性能;

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

2、应用场景

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

  • 大型网站的头部和底部,静态化之后统一加载;

  • 媒体网站,内容经过渲染,直接转为HTML网页;

  • 高并发下,CDN边缘节点代理的静态网页;

  • 电商网站中,复杂的产品详情页处理;

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

二、流程分析

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

SpringBoot2中如何使用FreeMarker模板完成页面静态化处理

  • 开发一个页面模板,即静态网页样式;

  • 提供接口,给页面模板获取数据;

  • 页面模板中编写数据接口返参的解析流程;

  • 基于解析引擎,把数据和页面模板合并;

  • 页面模板内容加载完成后转换为HTML静态页面;

  • HTML静态页面上传到文件服务器;

  • 客户端(Client)获取静态页面的url加载显示;

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

三、代码实现案例

1、基础依赖

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

<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-freemarker</artifactId></dependency>

2、页面模板

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

<html><head><title>PageStatic</title></head><body>主题:${myTitle}<br/><#assigntext="{'auth':'cicada','date':'2020-07-16'}"/><#assigndata=text?eval/>作者:${data.auth}日期:${data.date}<br/><tableclass="tabletable-stripedtable-hovertable-bordered"id="editable-sample"><thead><tr><th>规格描述</th><th>产品详情</th></tr></thead><tbody><#listtableListasinfo><trclass=""><td>${info.desc}</td><td><imgsrc="${info.imgUrl}"height="80"width="80"></td></tr></#list></tbody></table><br/><#listimgListasimgIF><imgsrc="${imgIF}"height="300"width="500"></#list></body></html>

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

3、解析过程

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

@ServicepublicclassPageServiceImplimplementsPageService{privatestaticfinalLoggerLOGGER=LoggerFactory.getLogger(PageServiceImpl.class);privatestaticfinalStringPATH="/templates/";@OverridepublicvoidftlToHtml()throwsException{//创建配置类Configurationconfiguration=newConfiguration(Configuration.getVersion());//设置模板路径Stringclasspath=this.getClass().getResource("/").getPath();configuration.setDirectoryForTemplateLoading(newFile(classpath+PATH));//加载模板Templatetemplate=configuration.getTemplate("my-page.ftl");//数据模型Map<String,Object>map=newHashMap<>();map.put("myTitle","页面静态化(PageStatic)");map.put("tableList",getList());map.put("imgList",getImgList());//静态化页面内容Stringcontent=FreeMarkerTemplateUtils.processTemplateIntoString(template,map);LOGGER.info("content:{}",content);InputStreaminputStream=IOUtils.toInputStream(content,"UTF-8");//输出文件FileOutputStreamfileOutputStream=newFileOutputStream(newFile("F:/page/newPage.html"));IOUtils.copy(inputStream,fileOutputStream);//关闭流inputStream.close();fileOutputStream.close();}privateList<TableInfo>getList(){List<TableInfo>tableInfoList=newArrayList<>();tableInfoList.add(newTableInfo(Constant.desc1,Constant.img01));tableInfoList.add(newTableInfo(Constant.desc2,Constant.img02));returntableInfoList;}privateList<String>getImgList(){List<String>imgList=newArrayList<>();imgList.add(Constant.img02);imgList.add(Constant.img02);returnimgList;}}
 </div> <div class="zixun-tj-product adv-bottom"></div> </div> </div> <div class="prve-next-news">
本文:SpringBoot2中如何使用FreeMarker模板完成页面静态化处理的详细内容,希望对您有所帮助,信息来源于网络。
上一篇:SpringBoot2中如何使用JTA组件实现多数据源事务管理下一篇:

17 人围观 / 0 条评论 ↓快速评论↓

(必须)

(必须,保密)

阿狸1 阿狸2 阿狸3 阿狸4 阿狸5 阿狸6 阿狸7 阿狸8 阿狸9 阿狸10 阿狸11 阿狸12 阿狸13 阿狸14 阿狸15 阿狸16 阿狸17 阿狸18