渲染Web页面
在之前的示例中,我们都是通过@RestController来处理请求,所以返回的内容为json对象。那么如果需要渲染html页面的时候,要如何实现呢?
模板引擎在动态HTML实现上Spring Boot依然可以完美胜任,并且提供了多种模板引擎的默认配置支持,所以在推荐的模板引擎下,我们可以很快的上手开发动态网站。
Spring Boot提供了默认配置的模板引擎主要有以下几种:其实就是动态页面静态化
Thymeleaf
FreeMarker
Velocity
Groovy
Mustache
当你使用上述模板引擎中的任何一个,它们默认的模板配置路径为:src/main/resources/templates。当然也可以修改这个路径,具体如何修改,可在后续各模板引擎的配置属性中查询并修改。
使用Freemarker模板引擎渲染web视图
1.pom文件引入Freemarker
<!--使用freemarker模板引擎--> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-freemarker</artifactId> </dependency>
2.后台代码
当返回一个字符串时,说明返回的是一个页面
/** * 引用模板引擎渲染wab页面 * Created by lizhen on 2018/2/6. */ @Controller public class IndexController { @RequestMapping("/IndexController") public String index(Map<String, Object> result) { System.out.println("index ......."); result.put("name", "李振"); result.put("sex", 0); List list = new ArrayList(); list.add("zhangsan"); list.add("lisi"); result.put("user", list); return "index"; } }
3.前台代码
在src/main/resources/创建一个templates文件夹,后缀为index.ftl
4.浏览器输入网址查看效果
5.Freemarker配置
我们配置的时候都是在application.properties文件配置的
具体的什么意思,可以百度,我们只是一个简单的例子,不做过多讲解
###FREEMARKER (FreeMarkerAutoConfiguration)
########################################################
spring.freemarker.allow-request-override=false
spring.freemarker.cache=true
spring.freemarker.check-template-location=true
spring.freemarker.charset=UTF-8
spring.freemarker.content-type=text/html
spring.freemarker.expose-request-attributes=false
spring.freemarker.expose-session-attributes=false
spring.freemarker.expose-spring-macro-helpers=false
#spring.freemarker.prefix=
#spring.freemarker.request-context-attribute=
#spring.freemarker.settings.*=
spring.freemarker.suffix=.ftl
spring.freemarker.template-loader-path=classpath:/templates/
#comma-separated list
#spring.freemarker.view-names= # whitelist of view names that can be resolved