Spring Boot整合FreeMarker模板

整合过程中所使用的工具

jdk:1.8
开发工具:idea
1.创建项目,添加依赖
首先创建Spring Boot项目,然后添加 spring-boot-starter-web 和 spring-boot-starter-freemarker依赖,代码如下:

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

2.配置FreeMarker
Spring Boot对FreeMarker也提供了自动化配置类 FreeMarkerAutoConfiguration,相关的配置属性在 FreeMarkerProperties中,FreeMarkerProperties部分源码如下:

@ConfigurationProperties(
    prefix = "spring.freemarker"
)
public class FreeMarkerProperties extends AbstractTemplateViewResolverProperties {
    public static final String DEFAULT_TEMPLATE_LOADER_PATH = "classpath:/templates/";
    public static final String DEFAULT_PREFIX = "";
    public static final String DEFAULT_SUFFIX = ".ftlh";

从该默认配置中可以看出来,FreeMarker默认模板位置在classpath:/templates/中,默认文件后缀是.ftlh (这里标记以下,应该是我用的最新版的原因,以前的旧版本后缀名一般是 .ftl) 开发者可以在application.properties中对这些默认配置进行修改,部分常见配置如下:

#HttpServletRequest 的属性是否可以覆盖 controller 中 model 的同命项
spring.freemarker.allow-request-override=false
#HttpSession 的属性是否可以覆盖 controller 中 model 的同名项
spring.freemarker.allow-session-override=false
#是否开启缓存
spring.freemarker.cache=false
#模板文件编码
spring.freemarker.charset=UTF-8
#是否检查模板位置
spring.freemarker.check-template-location=true
#Content-Type的值
spring.freemarker.content-type=text/html
#是否将 HttpServletRequest中的值添加到Model中
spring.freemarker.expose-request-attributes=false
#是否将 HttpServletSession中的值添加到Model中
spring.freemarker.expose-session-attributes=false
#模板文件后缀(由于新版后缀名是.ftlh,有些同学对新版本后缀名不熟悉,可以自己修改为原来的.ftl)
spring.freemarker.suffix=.ftl 
#模板文件位置
spring.freemarker.template-loader-path=classpath:/templates/

3.配置实体类和控制层
实体类代码如下:

import java.io.Serializable;

public class Book implements Serializable {
    private static final long serialVersionUID = 7617283173681831558L;
    private Integer id;
    private String name;
    private String author;

    public Book() {
    }

    public Book(Integer id, String name, String author) {
        this.id = id;
        this.name = name;
        this.author = author;
    }

    public Integer getId() {
        return id;
    }

    public void setId(Integer id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String getAuthor() {
        return author;
    }

    public void setAuthor(String author) {
        this.author = author;
    }

    @Override
    public String toString() {
        return "Book{" +
                "id=" + id +
                ", name='" + name + '\'' +
                ", author='" + author + '\'' +
                '}';
    }
}

控制层代码如下:

@Controller
public class BookController {
    @GetMapping("/books")
    public ModelAndView books(){
        List<Book> books = new ArrayList<>();
        Book b1 = new Book(1,"三国演义","罗贯中");
        Book b2 = new Book(2,"红楼梦","曹雪芹");
        books.add(b1);
        books.add(b2);
        ModelAndView mv = new ModelAndView();
        mv.addObject("books",books);
        mv.setViewName("books");
        return mv;
    }
}

4.创建视图
按照配置文件,在resources/templates 目录下创建 books.ftl文件,内容如下:
在这里插入图片描述

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>图书列表</title>
</head>
<body>
<table border="1">
    <tr>
        <td>图书编号</td>
        <td>图书名称</td>
        <td>图书作者</td>
    </tr>
    <#if books ?? && (books?size>0)>
        <#list books as book>
            <tr>
                <td>${book.id}</td>
                <td>${book.name}</td>
                <td>${book.author}</td>
            </tr>
        </#list>
    </#if>
</table>
</body>
</html>

通过<#if></#if>来判断集合中是否有数据
通过<#list></#list>来遍历集合,将数据展示出来
5.运行
在浏览器输入 “http://localhost:8080/books”,即可看到运行结果,如下图所示:
在这里插入图片描述
关于FreeMarker的更多资料,可以查看官网:https://freemarker.apache.org/

发布了24 篇原创文章 · 获赞 47 · 访问量 4096

猜你喜欢

转载自blog.csdn.net/qq_43647359/article/details/103773598