Spring MVC 支持多种模板技术,如 JSP、FreeMarker、Thymeleaf 等。Spring Boot 官方并不推荐使用 JSP 模板引擎,如果有可能,应尽量避免使用 JSP,因为当使用嵌入式 Servlet 容器时,对使用 JSP 模板引擎有几个已知的限制,以下是 Spring Boot 支持自动配置的模板引擎(其中并不包含 JSP):

  • FreeMarker
  • Groovy
  • Thymeleaf
  • Mustache

pom.xml 配置文件中添加内嵌 Tomcat 容器依赖,scope 声明为 provided:

1
2
3
4
5
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-tomcat</artifactId>
<scope>provided</scope>
</dependency>

pom.xml 配置文件中添加 JSP 编译依赖,否则启动报错:

1
2
3
4
<dependency>
<groupId>org.apache.tomcat.embed</groupId>
<artifactId>tomcat-embed-jasper</artifactId>
</dependency>

packaging 一定要声明为 war 类型,否则打包运行出错,完整配置:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>org.fanlychie</groupId>
<artifactId>spring-boot-jsp-sample</artifactId>
<packaging>war</packaging>
<version>0.0.1-SNAPSHOT</version>
<name>spring-boot-jsp-sample</name>
<url>http://maven.apache.org</url>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>1.5.2.RELEASE</version>
</parent>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-tomcat</artifactId>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>org.apache.tomcat.embed</groupId>
<artifactId>tomcat-embed-jasper</artifactId>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>

1. 控制器

1
2
3
4
5
6
7
8
9
10
@Controller
public class WelcomeController {
@GetMapping("/")
public String welcome(ModelMap model) {
model.put("message", "Hello JSP!");
return "index";
}
}

2. 主应用程序类

1
2
3
4
5
6
7
8
@SpringBootApplication
public class Application {
public static void main(String[] args) {
SpringApplication.run(Application.class);
}
}

3. 配置文件

在 Spring Boot 中使用 JSP 模板引擎有几个已知的限制,Spring Boot 对 JSP 模板引擎没有提供自动配置的支持,你需要手工配置视图模板文件信息。application.yml 配置示例:

1
2
3
4
5
6
7
spring:
main:
banner-mode: 'off'
mvc:
view:
prefix: /WEB-INF/pages/
suffix: .jsp

4. 模板文件

src/main/webapp/WEB-INF/pages/index.jsp

1
2
3
4
5
6
7
8
9
10
<%@ page pageEncoding="UTF-8" %>
<html>
<head>
<title>欢迎页</title>
<link href="/css/main.css" rel="stylesheet" />
</head>
<body>
<h1>${message}</h1>
</body>
</html>

5. 静态文件

Spring Boot 默认将静态资源文件映射到类路径下的目录包括(详见 ResourcesProperties):

  • /META-INF/resources/
  • /resources/
  • /static/
  • /public/

因此我们可以将 css、js、images 等静态资源文件放在/src/main/resources/static/目录下。

# src/main/resources/static/css/main.css


1
2
3
4
5
6
7
8
9
body {
padding: 0;
color: #444;
width: 280px;
margin: 100px auto;
font-family: SimSun;
background-color: #FBFBFB;
text-shadow: rgba(50,50,50,0.3) 2px 2px 3px;
}

6. 模板文件和静态资源文件的缓存问题

当修改 css、js 等静态资源文件的内容或模板文件的内容时,刷新客户端浏览器,发现内容还是老的,说明 Spring Boot 内置的 Servelt 容器并没有实时重新加载修改过的文件内容。你只能在每次修改静态资源文件时,虽然不需要重启服务,但是你要重新编译一次,IntelliJ IDEA 中按一次 Ctrl + F9 即可。
实现热加载(live reload)可参考:解决 IntelliJ IDEA 无法热加载 Spring Boot 模板文件和静态资源文件

示例项目开发环境:Java-8、Maven-3、IntelliJ IDEA-2017、Spring Boot-1.5.2.RELEASE
完整示例项目链接:spring-boot-jsp-sample