59分布式电商项目 - FreeMarker 入门demo

简介: 59分布式电商项目 - FreeMarker 入门demo

Demo代码已上传至Github

地址:https://github.com/ylw-github/FreeMarker-Demo.git

下面来讲解FreeMarker的集成步骤。

1.工程依赖引入
<dependency>
   <groupId>org.freemarker</groupId> 
   <artifactId>freemarker</artifactId> 
   <version>2.3.23</version>
 </dependency>
2. 创建模板文件(ftl文件)

模板文件中四种元素

  1. 文本,直接输出的部分
  2. 注释,即<#–…-->格式不会输出
  3. 插值(Interpolation):即${…}部分,将使用数据模型中的部分替代输出。
  4. FTL 指令:FreeMarker 指令,和 HTML 标记类似,名字前加#予以区分,不会输出。

现在创建一个简单的创建模板文件 test.ftl

<html>
  <head>
    <meta charset="utf-8">
    <title>Freemarker 入门小 DEMO </title>
  </head>
  <body>
    <#--我只是一个注释,我不会有任何输出 -->
    ${name},你好。${message}
  </body>
</html>

这里有文本、插值和注释

3.生成文件

使用步骤:

  1. 创建一个 Configuration 对象,直接 new 一个对象。构造方法的参数就是freemarker 的版本号。
  2. 设置模板文件所在的路径。
  3. 设置模板文件使用的字符集。一般就是 utf-8
  4. 加载一个模板,创建一个模板对象。
  5. 创建一个模板使用的数据集,可以是 pojo 也可以是 map。一般是 Map。
  6. 创建一个 Writer 对象,一般创建一 FileWriter 对象,指定生成的文件名。
  7. 调用模板对象的 process 方法输出文件。
  8. 关闭流。

代码:

创建 Test 类 main 方法如下:

//1.创建配置类
Configuration configuration=new Configuration(Configuration.getVersion());
//2.设置模板所在的目录
configuration.setDirectoryForTemplateLoading(newFile("D:/pinyougou_work/freemarkerDemo/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", "欢迎来到神奇的品优购世界!");
//6.创建 Writer 对象
Writer out =new FileWriter(new File("d:\\test.html"));
//7.输出
template.process(map, out);//8.关闭 Writer 对象out.close();

执行后,在 D 盘根目录即可看到生成的 test.html ,打开看看

目录
相关文章
|
3月前
|
存储 SQL 分布式数据库
OceanBase 入门:分布式数据库的基础概念
【8月更文第31天】在当今的大数据时代,随着业务规模的不断扩大,传统的单机数据库已经难以满足高并发、大数据量的应用需求。分布式数据库应运而生,成为解决这一问题的有效方案之一。本文将介绍一款由阿里巴巴集团自主研发的分布式数据库——OceanBase,并通过一些基础概念和实际代码示例来帮助读者理解其工作原理。
312 0
|
30天前
|
消息中间件 关系型数据库 Java
‘分布式事务‘ 圣经:从入门到精通,架构师尼恩最新、最全详解 (50+图文4万字全面总结 )
本文 是 基于尼恩之前写的一篇 分布式事务的文章 升级而来 , 尼恩之前写的 分布式事务的文章, 在全网阅读量 100万次以上 , 被很多培训机构 作为 顶级教程。 此文修改了 老版本的 一个大bug , 大家不要再看老版本啦。
|
2月前
|
NoSQL Java Redis
面试官:项目中如何实现分布式锁?
面试官:项目中如何实现分布式锁?
91 6
面试官:项目中如何实现分布式锁?
|
2月前
|
Dubbo Java 应用服务中间件
分布式-dubbo的入门
分布式-dubbo的入门
|
3月前
|
机器学习/深度学习 并行计算 PyTorch
PyTorch与DistributedDataParallel:分布式训练入门指南
【8月更文第27天】随着深度学习模型变得越来越复杂,单一GPU已经无法满足训练大规模模型的需求。分布式训练成为了加速模型训练的关键技术之一。PyTorch 提供了多种工具来支持分布式训练,其中 DistributedDataParallel (DDP) 是一个非常受欢迎且易用的选择。本文将详细介绍如何使用 PyTorch 的 DDP 模块来进行分布式训练,并通过一个简单的示例来演示其使用方法。
317 2
|
3月前
|
资源调度 Java 调度
项目环境测试问题之Schedulerx2.0通过分布式分片任务解决单机计算瓶颈如何解决
项目环境测试问题之Schedulerx2.0通过分布式分片任务解决单机计算瓶颈如何解决
项目环境测试问题之Schedulerx2.0通过分布式分片任务解决单机计算瓶颈如何解决
|
3月前
|
存储 缓存 开发框架
看看 Asp.net core Webapi 项目如何优雅地使用分布式缓存
看看 Asp.net core Webapi 项目如何优雅地使用分布式缓存
|
4月前
|
SQL NoSQL Java
如何在Java项目中实现分布式锁
如何在Java项目中实现分布式锁
|
5月前
|
存储 搜索推荐 Java
微服务SpringCloud ES分布式全文搜索引擎简介 下载安装及简单操作入门
微服务SpringCloud ES分布式全文搜索引擎简介 下载安装及简单操作入门
77 2
|
4月前
|
消息中间件 Java 中间件
如何在Java项目中实现分布式事务管理
如何在Java项目中实现分布式事务管理

热门文章

最新文章