springboot 通过SpringTemplateEngine渲染html

要单独获取到渲染后的 HTML 字符串,便于进行其他操作,可以通过以下几种方式实现。常见的用法是通过 Spring 的 Thymeleaf 模板引擎渲染模板为 HTML 字符串,而不是直接将其输出到浏览器。这样你就可以对渲染后的字符串进行其他操作,比如保存到文件或进一步处理。

1. 使用 Thymeleaf 渲染为字符串

你可以使用 ThymeleafTemplateEngine 手动渲染模板为字符串。需要通过 TemplateEngine 渲染模板文件,并且将渲染后的 HTML 作为一个字符串返回。你可以创建一个自定义的服务来处理这个需求。

1.1 添加依赖

除了 Thymeleaf 依赖之外,还需要确保有 Spring Web 和 Thymeleaf 依赖在 pom.xml 中:

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-thymeleaf</artifactId>
</dependency>
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-web</artifactId>
</dependency>
1.2 自定义服务类渲染 Thymeleaf 模板为字符串
import org.springframework.stereotype.Service;
import org.thymeleaf.TemplateEngine;
import org.thymeleaf.context.Context;

import java.util.Map;

@Service
public class HtmlRenderingService {

    private final TemplateEngine templateEngine;

    public HtmlRenderingService(TemplateEngine templateEngine) {
        this.templateEngine = templateEngine;
    }

    public String renderHtml(String templateName, Map<String, Object> variables) {
        // 创建一个上下文对象
        Context context = new Context();
        // 将传递的变量设置到上下文
        context.setVariables(variables);
        // 渲染指定模板为字符串
        return templateEngine.process(templateName, context);
    }
}
  • templateEngine.process() 会根据提供的模板名称和上下文变量,渲染出最终的 HTML 字符串。
  • variables 是一个 Map 对象,用于传递到模板中的变量。
1.3 控制器调用服务类渲染 HTML 字符串

你可以在控制器中调用这个服务,将模板渲染为字符串,并执行你想要的操作(如返回、保存、日志等)。

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;

import java.util.HashMap;
import java.util.Map;

@RestController
public class HtmlRenderController {

    @Autowired
    private HtmlRenderingService htmlRenderingService;

    @GetMapping("/render-html")
    public String renderHtml() {
        // 假设要传递的热点资源和推荐资源数据
        HotResource hotResource = new HotResource("热点资源1", "12345", "67890");

        Map<String, Object> variables = new HashMap<>();
        variables.put("hotResource", hotResource);

        return htmlRenderingService.renderHtml("resources", variables);
    }
}

在上面的代码中,当你访问 /render-html 这个接口时,控制器会调用 HtmlRenderingService 服务,将 resources.html 模板渲染为字符串并返回。

1.4 Thymeleaf 模板文件 (resources.html)

你可以使用和之前一样的 Thymeleaf 模板文件进行动态渲染,例如:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>资源推荐</title>
    <!-- 样式略 -->
</head>
<body>
    <div class="container">
        <div class="section">
            <h2>热点资源</h2>
            <div class="item hot-resource">
                <a th:href="@{/resource/hot(id=${hotResource.resourceId})}" target="_blank" th:text="${hotResource.name}">热点资源名称</a>
                <p th:text="'资源ID:' + ${hotResource.resourceId}">资源ID</p>
                <p th:text="'热点记录ID:' + ${hotResource.recordId}">热点记录ID</p>
            </div>
        </div>
    </div>
</body>
</html>

2. 渲染 HTML 后进行其他操作

通过上述方式获取的 HTML 字符串,你可以在控制器中进行任意操作:

  • 返回 HTML 字符串:直接返回渲染后的 HTML 字符串给前端。
  • 保存 HTML 文件:将 HTML 字符串保存到服务器上的某个文件。
  • 传递到其他服务:你可以将这个字符串发送到其他服务或系统。

例如,将渲染后的 HTML 保存为文件:

import java.io.FileWriter;
import java.io.IOException;

public class HtmlFileWriter {

    public static void saveHtmlToFile(String htmlContent, String filePath) throws IOException {
        FileWriter fileWriter = new FileWriter(filePath);
        fileWriter.write(htmlContent);
        fileWriter.close();
    }
}

在控制器中调用这个方法:

@GetMapping("/save-html")
public String saveHtmlToFile() {
    HotResource hotResource = new HotResource("热点资源1", "12345", "67890");

    Map<String, Object> variables = new HashMap<>();
    variables.put("hotResource", hotResource);

    String renderedHtml = htmlRenderingService.renderHtml("resources", variables);
    
    try {
        HtmlFileWriter.saveHtmlToFile(renderedHtml, "/path/to/save/file.html");
        return "HTML file saved successfully!";
    } catch (IOException e) {
        e.printStackTrace();
        return "Failed to save HTML file!";
    }
}

总结

通过上述方案,你可以:

  • 动态渲染 HTML 页面为字符串。
  • 根据需要返回 HTML 字符串、保存到文件或进行其他处理。

使用 Thymeleaf 渲染为字符串的方式非常灵活,适合你进行更多自定义操作。

上一篇:YOLOv11在目标检测中的应用及其与PaddleDetection的对比


下一篇:【Jenkins】解决使用容器化部署的Jenkins Agent节点时出现的git检查报错