在 Spring Boot 应用程序中提供 HTML 页面
Posted
技术标签:
【中文标题】在 Spring Boot 应用程序中提供 HTML 页面【英文标题】:Serving HTML pages in a Spring Boot application 【发布时间】:2016-02-11 23:12:51 【问题描述】:我有一个 Spring Boot 应用程序。我正在尝试将变量传递给 html 页面,但不幸的是我似乎无法做到这一点,在应用程序启动时,除了静态文本:“WORLD”之外,什么都没有呈现。我的控制器如下:
@Controller
public class IndexController
@RequestMapping(value = "/index", method = RequestMethod.GET)
public String index(Model model)
model.addAttribute("message", "HELLO");
return "index";
还有我的 index.html:
<html>
<body>
<h1>$message</h1>
<h2>WORLD</h2>
</body>
</html>
我一直在寻找答案,我找到了这些文章:
How to serve .html files with Spring
How to serve html files with Spring
How to handle static content in Spring MVC?
这些都是有用的示例,但在我的项目中,我没有文件,例如:mvc-dispatcher-servlet.xml、web.xml,甚至整个 WEB-INF 目录。
我在创建 Spring MVC 项目后拥有的文件在下面的屏幕截图中。我应该添加上述文献中提到的文件来解决这个问题还是什么?
通过 IntelliJ IDEA 查看我的项目:
我的 pom.xml 文件:
<?xml version="1.0" encoding="UTF-8"?>
<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/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>offersmanager</groupId>
<artifactId>webapp</artifactId>
<version>1</version>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>1.2.6.RELEASE</version>
</parent>
<properties>
<!-- Java version -->
<java.version>1.8</java.version>
<!-- Use UTF-8 sources encoding -->
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties>
<dependencies>
<!-- Local model -->
<dependency>
<groupId>$project.groupId</groupId>
<artifactId>model</artifactId>
<version>$project.version</version>
</dependency>
<!-- Spring boot -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-thymeleaf</artifactId>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
<!-- MAIN CODE SETTINGS -->
<sourceDirectory>src/main/java</sourceDirectory>
<resources>
<resource>
<directory>src/main/resources</directory>
<filtering>true</filtering>
</resource>
</resources>
<!-- TEST CODE SETTINGS -->
<testSourceDirectory>src/test/java</testSourceDirectory>
<testResources>
<testResource>
<directory>src/test/resources</directory>
</testResource>
</testResources>
</build>
<repositories>
<repository>
<id>spring-releases</id>
<url>https://repo.spring.io/libs-release</url>
</repository>
</repositories>
<pluginRepositories>
<pluginRepository>
<id>spring-releases</id>
<url>https://repo.spring.io/libs-release</url>
</pluginRepository>
</pluginRepositories>
</project>
【问题讨论】:
发布您的 POM。 “HTML 文件”不能有变量,但模板可以,设置它们的正确方法取决于特定的模板技术。 【参考方案1】:您正在使用 Thymeleaf 作为您的模板语言,您应该为此 read the documentation。在 Thymeleaf 中,要替换变量,您将在 HTML 标记上使用属性,如下所示:
<html>
<body>
<h1 data-th-text="$message">this gets replaced</h1>
<h2>WORLD</h2>
</body>
</html>
【讨论】:
是的,我没有注意到,因为这个项目不是我配置的。更改后完美运行:) 但是是否可以将项目配置为使用 JSP 文件而不是 html 文件而不使用模板语言? @KrzysiekZienkiewicz 当然; Spring Boot 几乎可以做任何事情。但是,如果您可以选择,出于多种原因,我强烈推荐 Thymeleaf。以上是关于在 Spring Boot 应用程序中提供 HTML 页面的主要内容,如果未能解决你的问题,请参考以下文章
174. Spring Boot WebSocket:群聊-昵称
172.Spring Boot WebSocket:编码分析