当前位置 : 主页 > 编程语言 > java >

SpringBoot整合Freemarker实现页面静态化

来源:互联网 收集:自由互联 发布时间:2022-10-26
第一步:创建项目添加依赖: !--web和actuator(图形监控用)基本上都是一起出现的--dependency groupIdorg.springframework.boot/groupId artifactIdspring-boot-starter-web/artifactId/dependencydependency groupIdorg.spring

第一步:创建项目添加依赖:

<!--web和actuator(图形监控用)基本上都是一起出现的--> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> <scope>test</scope> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-freemarker</artifactId> </dependency>

第二步:修改application.yml文件:

spring: freemarker: charset: UTF-8 #设定Template的编码 suffix: .ftl #后缀名 template-loader-path: classpath:/templates/ #模板加载路径,多个以逗号分隔,默认: [“classpath:/templates/”] cache: false #缓存配置,是否开启template caching enabled: true #是否允许mvc使用freemarker

第三步:在resources/templates目录下创建模板文件index.ftl:

<html> <head> <title>${title}</title> </head> <body> <h2>${msg}</h2> </body> </html>

第四步:创建代码静态化工具类:

@Component public class GenUtil { //创建Freemarker配置实例 @Resource private Configuration configuration; /** * 根据模板,利用提供的数据,生成文件 * * @param sourceFile 模板文件,带路径 * @param data 数据 * @param aimFile 最终生成的文件,若不带路径,则生成到当前项目的根目录中 */ public void gen(String sourceFile, String aimFile, Map<String, Object> data) { try { //加载模板文件 Template template = configuration.getTemplate(sourceFile); Writer out = new BufferedWriter(new OutputStreamWriter(new FileOutputStream(aimFile), StandardCharsets.UTF_8)); template.process(data, out); out.flush(); out.close(); } catch (IOException | TemplateException e) { e.printStackTrace(); } } }

第五步:静态化测试

@SpringBootTest public class GenTest { @Resource private GenUtil genUtil; @Test void fun(){ Map<String, Object> map = new HashMap<>(); map.put("title", "首页"); map.put("msg", "好好学习,天天向上!"); FreemarkerUtil.execute("index.ftl", "haha.html", map); } }

测试

运行测试代码发现在当前项目根目录下生成了一个haha.html的文件。

上一篇:SpringMVC重定向和转发
下一篇:没有了
网友评论