我的编程空间,编程开发者的网络收藏夹
学习永远不晚

SpringBoot2怎么使用FreeMarker模板完成页面静态化处理

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

SpringBoot2怎么使用FreeMarker模板完成页面静态化处理

这篇文章主要介绍“SpringBoot2怎么使用FreeMarker模板完成页面静态化处理”,在日常操作中,相信很多人在SpringBoot2怎么使用FreeMarker模板完成页面静态化处理问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”SpringBoot2怎么使用FreeMarker模板完成页面静态化处理”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

一、页面静态化

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/><#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">    <thead>    <tr>        <th>规格描述</th>        <th>产品详情</th>    </tr>    </thead>    <tbody>             <#list tableList as info>             <tr class="">                 <td>${info.desc}</td>                 <td><img class="lazy" data-src="${info.imgUrl}" height="80" width="80"></td>             </tr>             </#list>    </tbody></table><br/><#list imgList as imgIF>    <img class="lazy" data-src="${imgIF}" height="300" width="500"></#list></body></html>

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

3、解析过程

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

@Servicepublic 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<String, Object> map = new HashMap<>();        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<TableInfo> getList (){        List<TableInfo> tableInfoList = new ArrayList<>() ;        tableInfoList.add(new TableInfo(Constant.desc1, Constant.img01));        tableInfoList.add(new TableInfo(Constant.desc2,Constant.img02));        return tableInfoList ;    }    private List<String> getImgList (){        List<String> imgList = new ArrayList<>() ;        imgList.add(Constant.img02) ;        imgList.add(Constant.img02) ;        return imgList ;    }}

到此,关于“SpringBoot2怎么使用FreeMarker模板完成页面静态化处理”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

SpringBoot2怎么使用FreeMarker模板完成页面静态化处理

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

SpringBoot2怎么使用FreeMarker模板完成页面静态化处理

这篇文章主要介绍“SpringBoot2怎么使用FreeMarker模板完成页面静态化处理”,在日常操作中,相信很多人在SpringBoot2怎么使用FreeMarker模板完成页面静态化处理问题上存在疑惑,小编查阅了各式资料,整理出简单好
2023-07-06

Java怎么使用Freemarker生成页面静态化

本篇内容介绍了“Java怎么使用Freemarker生成页面静态化”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!前言:页面静态化其实就是将原
2023-07-02

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录