0

0

Spring Boot中特定字段到HTML页面的映射与渲染

碧海醫心

碧海醫心

发布时间:2025-09-27 09:52:13

|

557人浏览过

|

来源于php中文网

原创

Spring Boot中特定字段到HTML页面的映射与渲染

本文详细介绍了如何在Spring Boot应用中,从控制器获取数据并仅将特定字段(如title和description)渲染到HTML页面。我们将探讨使用数据传输对象(DTO)进行数据投影的最佳实践,以及如何结合Thymeleaf等模板引擎实现动态HTML生成。同时,也会提及@JsonIgnore注解在API响应过滤中的应用,以区分其与HTML渲染的不同场景。

1. 理解核心需求:数据投影与HTML渲染

在spring boot中,当控制器返回一个对象列表时,默认情况下会将其序列化为json格式。然而,用户的核心需求是将这些数据中的特定字段(例如title和description)呈现在一个html页面上,而不是直接返回json。这涉及到两个关键概念:

  1. 数据投影(Data Projection):从原始数据对象中选择并提取所需的特定字段。
  2. HTML渲染(HTML Rendering):使用模板引擎将处理后的数据嵌入到HTML模板中,生成最终的网页内容。

为了实现这一目标,我们需要调整控制器以返回视图名称,并通过Spring的Model接口将数据传递给模板引擎。

2. 配置模板引擎

Spring Boot通常与Thymeleaf模板引擎配合使用。如果项目中尚未添加Thymeleaf依赖,请在pom.xml中加入:


    org.springframework.boot
    spring-boot-starter-thymeleaf

默认情况下,Thymeleaf模板文件应放置在src/main/resources/templates/目录下。

3. 使用数据传输对象(DTO)进行数据投影

直接将完整的实体类(如AdventureHolidays)传递给视图层或API响应通常不是最佳实践。原因如下:

立即学习前端免费学习笔记(深入)”;

  • 数据暴露:实体类可能包含敏感或不必要的信息。
  • 职责分离:实体类代表数据库结构,而DTO代表视图或API所需的数据结构。
  • 性能优化:避免不必要的数据序列化或传输。

因此,推荐创建一个专门的DTO来封装视图所需的数据。

3.1 定义DTO

创建一个AdventureHolidayDto类,只包含title和description字段。

// src/main/java/com/example/demo/dto/AdventureHolidayDto.java
package com.example.demo.dto;

public class AdventureHolidayDto {
    private String title;
    private String description;

    // 构造函数
    public AdventureHolidayDto(String title, String description) {
        this.title = title;
        this.description = description;
    }

    // Getter方法
    public String getTitle() {
        return title;
    }

    public String getDescription() {
        return description;
    }

    // Setter方法 (如果需要)
    public void setTitle(String title) {
        this.title = title;
    }

    public void setDescription(String description) {
        this.description = description;
    }
}

3.2 修改服务层或控制器进行数据映射

在服务层(adventureHolidaysService)或控制器中,将AdventureHolidays实体列表转换为AdventureHolidayDto列表。

Adobe Firefly
Adobe Firefly

Adobe最新推出的AI图像生成和编辑工具

下载
// src/main/java/com/example/demo/controller/AdventureHolidaysController.java
package com.example.demo.controller;

import com.example.demo.model.AdventureHolidays;
import com.example.demo.service.AdventureHolidaysService;
import com.example.demo.dto.AdventureHolidayDto;
import org.springframework.stereotype.Controller; // 注意这里改为 @Controller
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.GetMapping;

import java.util.List;
import java.util.stream.Collectors;

@Controller // 使用 @Controller 返回视图名称
public class AdventureHolidaysController {

    private final AdventureHolidaysService adventureHolidaysService;

    public AdventureHolidaysController(AdventureHolidaysService adventureHolidaysService) {
        this.adventureHolidaysService = adventureHolidaysService;
    }

    @GetMapping("/getRandomSummerCampsHtml") // 更改路径以区分API接口
    public String getRandomSummerCampsHtml(Model model) {
        List entities = adventureHolidaysService.getRandomSummerCamps();

        // 将实体列表映射为DTO列表
        List dtos = entities.stream()
                .map(entity -> new AdventureHolidayDto(entity.getTitle(), entity.getDescription()))
                .collect(Collectors.toList());

        // 将DTO列表添加到Model中,以便在HTML模板中使用
        model.addAttribute("summerCamps", dtos);

        // 返回视图名称,Thymeleaf将查找 src/main/resources/templates/summerCamps.html
        return "summerCamps";
    }

    // 如果仍需要返回JSON API,可以保留原有的 @RestController 接口
    @GetMapping("/getRandomSummerCamps")
    public List getRandomSummerCamps() {
        return adventureHolidaysService.getRandomSummerCamps();
    }
}

注意:为了返回HTML页面,控制器需要使用@Controller注解,并且方法返回类型为String,代表视图的逻辑名称。如果控制器同时需要处理API请求(返回JSON),可以创建一个单独的@RestController,或者在同一个@Controller中使用@ResponseBody注解来标记返回JSON的方法。

4. 创建HTML模板

在src/main/resources/templates/目录下创建summerCamps.html文件。




    
    随机夏令营
    


    

随机夏令营列表

没有找到任何夏令营信息。

夏令营标题

夏令营描述内容。

在这个Thymeleaf模板中:

  • th:each="camp : ${summerCamps}" 迭代Model中名为summerCamps的列表。
  • th:text="${camp.title}" 和 th:text="${camp.description}" 分别将当前camp对象的title和description属性值插入到HTML元素中。

5. @JsonIgnore注解的应用场景

原始问题中提到了@JsonIgnore注解,它主要用于控制JSON序列化的行为,即当对象被转换为JSON字符串时,忽略带有此注解的字段。这与将数据渲染到HTML页面是两个不同的概念。

如果你希望通过原始的/getRandomSummerCamps API接口返回JSON时,不包含typeOfAdventureHolidays字段,那么可以在AdventureHolidays实体类上使用@JsonIgnore:

// src/main/java/com/example/demo/model/AdventureHolidays.java
package com.example.demo.model;

import com.fasterxml.jackson.annotation.JsonIgnore;
import org.springframework.data.annotation.Id;
import org.springframework.data.mongodb.core.mapping.Document;

@Document("adventureholidays")
public class AdventureHolidays {

    @Id
    private String id;
    private String title;
    private String description;
    @JsonIgnore // 此字段在JSON序列化时将被忽略
    private String typeOfAdventureHolidays;

    // Getter方法
    public String getId() { return id; }
    public String getTitle() { return title; }
    public String getDescription() { return description; }
    public String getTypeOfAdventureHolidays() { return typeOfAdventureHolidays; }

    // Setter方法 (如果需要)
    public void setId(String id) { this.id = id; }
    public void setTitle(String title) { this.title = title; }
    public void setDescription(String description) { this.description = description; }
    public void setTypeOfAdventureHolidays(String typeOfAdventureHolidays) { this.typeOfAdventureHolidays = typeOfAdventureHolidays; }
}

重要提示:@JsonIgnore只影响JSON序列化,不会影响你在Java代码中对该字段的访问,也不会直接影响Thymeleaf模板渲染,因为Thymeleaf是直接访问Java对象的Getter方法。

6. 总结与注意事项

  • HTML渲染:要将数据渲染到HTML页面,控制器方法应返回视图名称(String),并使用Model对象将数据传递给模板。
  • 数据投影:为了清晰、安全和高效,推荐使用DTO(Data Transfer Object)来封装视图或API所需的特定字段,避免直接暴露完整的实体对象。
  • 模板引擎:Spring Boot常用Thymeleaf作为模板引擎,通过th:属性将数据动态绑定到HTML元素。
  • @JsonIgnore:此注解用于控制JSON序列化过程,当需要从API响应中排除某些字段时使用,与HTML渲染是不同的应用场景。
  • 控制器类型:@Controller注解的类通常用于返回视图,而@RestController注解的类则用于构建RESTful API(默认返回JSON或XML)。如果一个控制器需要同时处理视图和API请求,可以混合使用@Controller和@ResponseBody,或者创建两个独立的控制器。

通过以上步骤,你就可以在Spring Boot中灵活地从后端获取数据,并根据前端需求精确地选择和渲染特定字段到HTML页面上。

相关专题

更多
java
java

Java是一个通用术语,用于表示Java软件及其组件,包括“Java运行时环境 (JRE)”、“Java虚拟机 (JVM)”以及“插件”。php中文网还为大家带了Java相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

719

2023.06.15

java流程控制语句有哪些
java流程控制语句有哪些

java流程控制语句:1、if语句;2、if-else语句;3、switch语句;4、while循环;5、do-while循环;6、for循环;7、foreach循环;8、break语句;9、continue语句;10、return语句。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

455

2024.02.23

java正则表达式语法
java正则表达式语法

java正则表达式语法是一种模式匹配工具,它非常有用,可以在处理文本和字符串时快速地查找、替换、验证和提取特定的模式和数据。本专题提供java正则表达式语法的相关文章、下载和专题,供大家免费下载体验。

722

2023.07.05

java自学难吗
java自学难吗

Java自学并不难。Java语言相对于其他一些编程语言而言,有着较为简洁和易读的语法,本专题为大家提供java自学难吗相关的文章,大家可以免费体验。

727

2023.07.31

java配置jdk环境变量
java配置jdk环境变量

Java是一种广泛使用的高级编程语言,用于开发各种类型的应用程序。为了能够在计算机上正确运行和编译Java代码,需要正确配置Java Development Kit(JDK)环境变量。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

394

2023.08.01

java保留两位小数
java保留两位小数

Java是一种广泛应用于编程领域的高级编程语言。在Java中,保留两位小数是指在进行数值计算或输出时,限制小数部分只有两位有效数字,并将多余的位数进行四舍五入或截取。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

398

2023.08.02

java基本数据类型
java基本数据类型

java基本数据类型有:1、byte;2、short;3、int;4、long;5、float;6、double;7、char;8、boolean。本专题为大家提供java基本数据类型的相关的文章、下载、课程内容,供大家免费下载体验。

441

2023.08.02

java有什么用
java有什么用

java可以开发应用程序、移动应用、Web应用、企业级应用、嵌入式系统等方面。本专题为大家提供java有什么用的相关的文章、下载、课程内容,供大家免费下载体验。

428

2023.08.02

ip地址修改教程大全
ip地址修改教程大全

本专题整合了ip地址修改教程大全,阅读下面的文章自行寻找合适的解决教程。

81

2025.12.26

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 2.1万人学习

C# 教程
C# 教程

共94课时 | 5.5万人学习

Java 教程
Java 教程

共578课时 | 38.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号