0

0

在Spring Boot中实现表单字段校验的教程

心靈之曲

心靈之曲

发布时间:2025-12-12 23:11:35

|

267人浏览过

|

来源于php中文网

原创

在Spring Boot中实现表单字段校验的教程

本教程详细介绍了如何在spring boot应用中实现表单字段校验,涵盖了服务器端和客户端两种方法。服务器端通过引入`spring-boot-starter-validation`依赖,在模型(pojo)中使用`@notblank`、`@min`等jsr 303/380注解,并在控制器方法中结合`@valid`和`@modelattribute`进行校验。客户端则利用html5的`required`属性和合适的`input`类型提供即时反馈。结合使用这两种方法能有效提升应用的数据完整性和用户体验。

在构建Web应用时,表单数据校验是确保数据完整性和提升用户体验的关键环节。Spring Boot提供了强大的校验机制,结合HTML5的客户端校验,可以构建健壮的表单处理流程。本教程将详细阐述如何在Spring Boot项目中为表单字段添加必填校验。

一、理解校验的重要性

在用户提交表单数据时,如果某些关键字段缺失或格式不正确,可能导致后端业务逻辑错误,甚至引发应用异常(如本例中未输入价格导致的Whitelabel Error Page)。因此,无论是在客户端还是服务器端,都必须对用户输入进行严格的校验。

二、服务器端校验:使用Spring Validation

Spring Boot通过集成JSR 303/380 (Bean Validation) 规范,提供了强大的服务器端校验能力。

1. 引入校验依赖

首先,需要在pom.xml文件中添加spring-boot-starter-validation依赖。这个依赖包含了Hibernate Validator,它是JSR 303/380规范的一个实现。


    org.springframework.boot
    spring-boot-starter-validation

2. 在模型(POJO)中定义校验规则

在代表表单数据的POJO类(例如Product类)的字段上,使用JSR 303/380提供的注解来定义校验规则。

  • @NotBlank: 适用于字符串,表示字段不能为空且不能只包含空白字符。
  • @NotNull: 适用于任何类型,表示字段不能为null。
  • @NotEmpty: 适用于字符串、集合、数组,表示字段不能为null且长度或大小不能为0。
  • @Min(value): 适用于数值类型,表示字段值必须大于或等于指定值。
  • @Max(value): 适用于数值类型,表示字段值必须小于或等于指定值。
  • @Size(min=x, max=y): 适用于字符串、集合、数组,表示字段的长度或大小必须在指定范围内。
  • @Email: 适用于字符串,表示字段必须是有效的电子邮件格式。

以下是为Product类添加校验注解的示例:

import jakarta.validation.constraints.Min;
import jakarta.validation.constraints.NotBlank;
import org.springframework.data.annotation.Id;
import org.springframework.data.mongodb.core.mapping.Document;

@Document(collection = "products")
public class Product {

    @Id
    private String id;

    @NotBlank(message = "产品名称不能为空") // 产品名称不能为空
    private String prodName;

    @NotBlank(message = "产品描述不能为空") // 产品描述不能为空
    private String prodDesc;

    @Min(value = 0, message = "产品价格不能为负数") // 产品价格不能小于0
    private Double prodPrice;

    // prodImage可以为空,如果需要必填,可以添加@NotBlank
    private String prodImage;

    public Product() {
    }

    public Product(String prodName, String prodDesc, Double prodPrice, String prodImage) {
        this.prodName = prodName;
        this.prodDesc = prodDesc;
        this.prodPrice = prodPrice;
        this.prodImage = prodImage;
    }

    // Getters and Setters
    public String getId() { return id; }
    public void setId(String id) { this.id = id; }
    public String getProdName() { return prodName; }
    public void setProdName(String prodName) { this.prodName = prodName; }
    public String getProdDesc() { return prodDesc; }
    public void setProdDesc(String prodDesc) { this.prodDesc = prodDesc; }
    public Double getProdPrice() { return prodPrice; }
    public void setProdPrice(Double prodPrice) { this.prodPrice = prodPrice; }
    public String getProdImage() { return prodImage; }
    public void setProdImage(String prodImage) { this.prodImage = prodImage; }
}

注意:@Min(0.01d)可以确保价格大于0,如果允许价格为0,则使用@Min(0d)。

3. 在控制器中触发校验

在控制器方法中,将表单数据绑定到带有校验注解的POJO对象上,并通过@Valid注解触发校验。同时,为了捕获校验结果,通常会紧跟一个BindingResult参数。

import jakarta.validation.Valid;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.validation.BindingResult;
import org.springframework.web.bind.annotation.*;

@Controller
public class ProductController {

    @Autowired
    ProductRepository productRepository;

    // ... 其他方法 ...

    @RequestMapping(value = "/save", method = RequestMethod.POST) // 推荐使用POST方法处理表单提交
    public String save(@Valid @ModelAttribute Product product, BindingResult bindingResult, Model model) {
        if (bindingResult.hasErrors()) {
            // 如果有校验错误,返回到创建页面并显示错误信息
            model.addAttribute("product", product); // 将带有错误的product对象传回表单
            model.addAttribute("errors", bindingResult.getAllErrors()); // 传递所有错误信息
            return "create"; // 返回到创建产品页面
        }

        productRepository.save(product);
        return "redirect:/show/" + product.getId();
    }

    @RequestMapping(value = "/update", method = RequestMethod.POST) // 推荐使用POST方法处理表单提交
    public String update(@Valid @ModelAttribute Product product, BindingResult bindingResult, Model model) {
        if (bindingResult.hasErrors()) {
            // 如果有校验错误,返回到编辑页面并显示错误信息
            model.addAttribute("product", product);
            model.addAttribute("errors", bindingResult.getAllErrors());
            return "edit"; // 返回到编辑产品页面
        }

        // 确保ID不丢失
        Optional existingProduct = productRepository.findById(product.getId());
        if (existingProduct.isPresent()) {
            Product p = existingProduct.get();
            p.setProdName(product.getProdName());
            p.setProdDesc(product.getProdDesc());
            p.setProdPrice(product.getProdPrice());
            p.setProdImage(product.getProdImage());
            productRepository.save(p);
        } else {
            // 处理产品不存在的情况,例如重定向到错误页或产品列表
            return "redirect:/product";
        }

        return "redirect:/show/" + product.getId();
    }

    @RequestMapping("/create")
    public String create(Model model) {
        model.addAttribute("product", new Product()); // 为表单提供一个空的Product对象
        return "create";
    }

    @RequestMapping("/edit/{id}")
    public String edit(@PathVariable String id, Model model) {
        model.addAttribute("product", productRepository.findById(id).orElse(new Product())); // 确保不会返回null
        return "edit";
    }

    // ... 其他方法 ...
}

重要提示

  • 将@RequestParam替换为@ModelAttribute Product product,这样Spring会自动将表单参数绑定到Product对象的属性上。
  • @Valid注解告诉Spring对Product对象执行校验。
  • BindingResult参数必须紧跟在@Valid参数之后,它包含了校验结果,通过hasErrors()方法可以判断是否存在错误。
  • 在create和edit方法中,确保为模板提供一个Product对象,以便Thymeleaf能够正确绑定表单数据和显示错误。

4. 在Thymeleaf模板中显示校验错误

当BindingResult检测到错误时,可以将错误信息传递回前端页面进行显示。

在create.html和edit.html中,可以这样显示错误信息:

VWO
VWO

一个A/B测试工具

下载

注意

  • th:field="*{prodName}" 是Thymeleaf的表单绑定语法,它会自动设置name、id和value属性。
  • th:classappend="${#fields.hasErrors('prodName')} ? 'has-error'" 会在字段有错误时添加has-error类,通常用于样式高亮。
  • th:errors="*{prodName}" 会显示该字段的错误消息。
  • th:if="${#fields.hasErrors('prodName')}" 用于条件性地显示错误消息。
  • 为了使th:field正常工作,form标签需要使用th:object="${product}"来指定绑定的对象。

修改create.html和edit.html的form标签如下:


三、客户端校验:使用HTML5 required属性

客户端校验可以在用户提交表单之前提供即时反馈,提升用户体验并减轻服务器压力。HTML5提供了required属性以及各种input类型(如type="number"、type="url")来实现基本的客户端校验。

1. 使用 required 属性

在需要必填的input、textarea或select元素上添加required属性。


注意

  • required属性是布尔属性,只需存在即生效。
  • type="number"会限制用户只能输入数字,并且浏览器会提供步进器(如果支持)。
  • type="url"会要求用户输入符合URL格式的字符串。
  • label的for属性应与input的id属性对应,以提高可访问性。为了避免冲突,建议将label的for属性值修改为与name属性值一致(或使用th:field自动生成的id)。

四、结合使用客户端与服务器端校验

最佳实践是同时使用客户端和服务器端校验:

  • 客户端校验:提供即时、友好的用户反馈,减少不必要的服务器请求。
  • 服务器端校验:作为最终防线,确保数据的完整性和安全性,因为客户端校验容易被绕过。

当客户端校验通过后,数据提交到服务器,服务器端会再次进行校验。如果服务器端校验失败,则将错误信息返回给客户端,由客户端页面显示。

五、总结

通过本教程,我们学习了如何在Spring Boot应用中实现表单字段的必填校验。核心步骤包括:

  1. 添加spring-boot-starter-validation依赖
  2. 在POJO模型中使用JSR 303/380校验注解(如@NotBlank, @Min)。
  3. 在控制器方法中使用@Valid和@ModelAttribute触发校验,并利用BindingResult处理校验结果。
  4. 在Thymeleaf模板中显示校验错误信息,并使用th:field进行表单绑定。
  5. 在HTML表单中使用required属性和合适的input类型进行客户端校验,提升用户体验。

结合使用这两种校验方法,能够有效地保障应用程序的数据质量,提高系统的健壮性和用户满意度。

相关专题

更多
spring框架介绍
spring框架介绍

本专题整合了spring框架相关内容,想了解更多详细内容,请阅读专题下面的文章。

105

2025.08.06

spring boot框架优点
spring boot框架优点

spring boot框架的优点有简化配置、快速开发、内嵌服务器、微服务支持、自动化测试和生态系统支持。本专题为大家提供spring boot相关的文章、下载、课程内容,供大家免费下载体验。

135

2023.09.05

spring框架有哪些
spring框架有哪些

spring框架有Spring Core、Spring MVC、Spring Data、Spring Security、Spring AOP和Spring Boot。详细介绍:1、Spring Core,通过将对象的创建和依赖关系的管理交给容器来实现,从而降低了组件之间的耦合度;2、Spring MVC,提供基于模型-视图-控制器的架构,用于开发灵活和可扩展的Web应用程序等。

389

2023.10.12

Java Spring Boot开发
Java Spring Boot开发

本专题围绕 Java 主流开发框架 Spring Boot 展开,系统讲解依赖注入、配置管理、数据访问、RESTful API、微服务架构与安全认证等核心知识,并通过电商平台、博客系统与企业管理系统等项目实战,帮助学员掌握使用 Spring Boot 快速开发高效、稳定的企业级应用。

68

2025.08.19

Java Spring Boot 4更新教程_Java Spring Boot 4有哪些新特性
Java Spring Boot 4更新教程_Java Spring Boot 4有哪些新特性

Spring Boot 是一个基于 Spring 框架的 Java 开发框架,它通过 约定优于配置的原则,大幅简化了 Spring 应用的初始搭建、配置和开发过程,让开发者可以快速构建独立的、生产级别的 Spring 应用,无需繁琐的样板配置,通常集成嵌入式服务器(如 Tomcat),提供“开箱即用”的体验,是构建微服务和 Web 应用的流行工具。

34

2025.12.22

Java Spring Boot 微服务实战
Java Spring Boot 微服务实战

本专题深入讲解 Java Spring Boot 在微服务架构中的应用,内容涵盖服务注册与发现、REST API开发、配置中心、负载均衡、熔断与限流、日志与监控。通过实际项目案例(如电商订单系统),帮助开发者掌握 从单体应用迁移到高可用微服务系统的完整流程与实战能力。

114

2025.12.24

html5动画制作有哪些制作方法
html5动画制作有哪些制作方法

html5动画制作方法有使用CSS3动画、使用JavaScript动画库、使用HTML5 Canvas等。想了解更多html5动画制作方法相关内容,可以阅读本专题下面的文章。

507

2023.10.23

HTML与HTML5的区别
HTML与HTML5的区别

HTML与HTML5的区别:1、html5支持矢量图形,html本身不支持;2、html5中可临时存储数据,html不行;3、html5新增了许多控件;4、html本身不支持音频和视频,html5支持;5、html无法处理不准确的语法,html5能够处理等等。想了解更多HTML与HTML5的相关内容,可以阅读本专题下面的文章。

430

2024.03.06

AO3中文版入口地址大全
AO3中文版入口地址大全

本专题整合了AO3中文版入口地址大全,阅读专题下面的的文章了解更多详细内容。

1

2026.01.21

热门下载

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

精品课程

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

共46课时 | 3万人学习

AngularJS教程
AngularJS教程

共24课时 | 2.8万人学习

CSS教程
CSS教程

共754课时 | 21.9万人学习

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

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