网页静态化技术 Freemarker 1.1 为什么要使用网页静态化技术网页静态化解决方案在实际开发中运用比较多,例如新闻网站,门户网站中的新闻频道或者是文章类的频道。
对于电商网站的商品详细页来说,至少几百万个商品,每个商品又有大量的信息,这样的情况同样也适用于使用网页静态化来解决。
网页静态化技术和缓存技术的共同点都是为了减轻数据库的访问压力,但是具体的应用场景不同,缓存比较适合小规模的数据,而网页静态化比较适合大规模且相对变化不太频繁的数据。另外网页静态化还有利于 SEO。
另外我们如果将网页以纯静态化的形式展现,就可以使用 Nginx 这样的高性能的 web 服务器来部署。Nginx 可以承载 5 万的并发,而 Tomcat 只有几百。关于 Nginx 我们在后续的课程中会详细讲解。 今天我们就研究网页静态化技术----Freemarker 。 1.1 什么是 Freemarker FreeMarker 是一个用 Java 语言编写的模板引擎, 它基于模板来生成文本输出。FreeMarker 与 Web 容器无关,即在 Web 运行时,它并不知道 Servlet 或 HTTP。它不仅可以用作表现层的实现技术,而且还可以用于生成 XML,JSP 或 Java 等。 1.1 Freemarker 入门小 DEMO 1.1.1 工程引入依赖 [AppleScript] 纯文本查看 复制代码 <dependency>
<groupId>org.freemarker</groupId>
<artifactId>freemarker</artifactId>
<version>2.3.23</version>
</dependency>
1.1.1 创建模板文件 模板文件中四种元素1、文本,直接输出的部分 2、注释,即<#--...-->格式不会输出 3、插值(Interpolation):即${..}部分,将使用数据模型中的部分替代输出 4、FTL 指令:FreeMarker 指令,和 HTML 标记类似,名字前加#予以区分,不会输出。我们现在就创建一个简单的创建模板文件 test.ftl [AppleScript] 纯文本查看 复制代码 <html>
<head>
<meta charset="utf-8">
<title>Freemarker 入门小 DEMO </title>
</head>
<body>
<#--我只是一个注释,我不会有任何输出 -->
${name},你好。${message}
</body>
</html> 这里有文本、插值和注释 1.1.1 生成文件 使用步骤: 第一步: 创建一个 Configuration 对象,直接 new 一个对象。构造方法的参数就是 freemarker 的版本号。 第二步:设置模板文件所在的路径。 第三步:设置模板文件使用的字符集。一般就是 utf-8. 第四步:加载一个模板,创建一个模板对象。 第五步:创建一个模板使用的数据集,可以是 pojo 也可以是 map。一般是 Map。第六步:创建一个 Writer 对象,一般创建一 FileWriter 对象,指定生成的文件名。第七步:调用模板对象的 process 方法输出文件。 第八步:关闭流 代码: 创建 Test 类 main 方法如下: [AppleScript] 纯文本查看 复制代码 //1.创建配置类
Configuration configuration=new Configuration(Configuration.getVersion());
//2.设置模板所在的目录configuration.setDirectoryForTemplateLoading(new
File("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 ,打开看看
|