FreeMarker相关配置

tech2025-04-08  7

FreeMarker

什么是freemarker

FreeMarker 是一款 模板引擎: 即一种基于模板和要改变的数据, 并用来生成输出文本(HTML网页,电子邮件,配置文件,源代码等)的通用工具。 它不是面向最终用户的,而是一个Java类库,是一款程序员可以嵌入他们所开发产品的组件。

这种方式通常被称为 MVC (模型 视图 控制器) 模式,对于动态网页来说,是一种特别流行的模式。

springboot如何集成freemarker模板引擎

添加依赖

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

配置属性文件

是否允许HttpServletRequest属性覆盖(隐藏)控制器生成的同名模型属性。

spring.freemarker.allow-request-override=false

是否允许HttpSession属性覆盖(隐藏)控制器生成的同名模型属性。

spring.freemarker.allow-session-override=false

是否启用模板缓存。

spring.freemarker.cache=false

模板编码。

spring.freemarker.charset=UTF-8

是否检查模板位置是否存在。

spring.freemarker.check-template-location=true Content-Type value. spring.freemarker.content-type=text/html

是否启用freemarker

spring.freemarker.enabled=true

设定所有request的属性在merge到模板的时候,是否要都添加到model中.

spring.freemarker.expose-request-attributes=false

是否在merge模板的时候,将HttpSession属性都添加到model中

spring.freemarker.expose-session-attributes=false

设定是否以springMacroRequestContext的形式暴露RequestContext给Spring’s macro library使用

spring.freemarker.expose-spring-macro-helpers=true

是否优先从文件系统加载template,以支持热加载,默认为true

spring.freemarker.prefer-file-system-access=true

设定模板的后缀.

spring.freemarker.suffix=.ftl

设定模板的加载路径,多个以逗号分隔,默认:

spring.freemarker.template-loader-path=classpath:/templates/

设定FreeMarker keys.

spring.freemarker.settings.template_update_delay=0 spring.freemarker.settings.default_encoding=UTF-8 spring.freemarker.settings.classic_compatible=true

application.yml文件添加

spring: freemarker: allow-request-override: false allow-session-override: false cache: false charset: UTF-8 check-template-location: true content-type: text/html enabled: true expose-request-attributes: false expose-session-attributes: false expose-spring-macro-helpers: true prefer-file-system-access: true suffix: .ftl template-loader-path: classpath:/templates/ settings: classic_compatible: true default_encoding: UTF-8 template_update_delay: 0
最新回复(0)