Spring Boot 2与Thymeleaf如何实现服务器端表单验证?

2026-06-09 05:2213阅读0评论SEO教程
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计1315个文字,预计阅读时间需要6分钟。

Spring Boot 2与Thymeleaf如何实现服务器端表单验证?

这篇文章主要介绍了Spring Boot 2与Thymeleaf服务端表单验证的实现,内容详尽,通过示例代码展示了操作过程。对于想学习或工作的朋友来说,这是一份很有参考价值的资料。需要的朋友可以参考以下内容:

表单验证

Spring Boot 2结合Thymeleaf实现表单验证,可以通过以下步骤进行:

1. 添加依赖:在`pom.xml`中添加Spring Boot和Thymeleaf的依赖。

2.创建表单页面:使用Thymeleaf模板引擎创建表单页面,并使用`th:field`标签绑定表单元素。

3.编写验证逻辑:在控制器中,通过`@Valid`注解标记接收表单数据的实体类,并使用`@Valid`注解标记表单提交的方法。

4.自定义验证器:如果需要自定义验证规则,可以创建一个实现了`Validator`接口的类,并在控制器中注入该验证器。

示例代码

以下是一个简单的示例,展示了如何使用Spring Boot 2和Thymeleaf实现表单验证:

java

// 表单实体类public class User { private String name; private String email;

// 省略getter和setter方法}

// 控制器@Controllerpublic class UserController { @Autowired private UserValidator userValidator;

@GetMapping(/register) public String showRegisterForm(Model model) { model.addAttribute(user, new User()); return register; }

@PostMapping(/register) public String registerUser(@Valid @ModelAttribute(user) User user, BindingResult bindingResult) { if (bindingResult.hasErrors()) { return register; } // 处理注册逻辑 return success; }}

// 自定义验证器public class UserValidator implements Validator { @Override public boolean supports(Class clazz) { return User.class.equals(clazz); }

@Override public void validate(Object target, Errors errors) { User user=(User) target; if (user.getName()==null || user.getName().isEmpty()) { errors.rejectValue(name, required, Name is required); } if (user.getEmail()==null || user.getEmail().isEmpty()) { errors.rejectValue(email, required, Email is required); } // 其他验证规则... }}

总结

通过以上内容,我们可以了解到Spring Boot 2与Thymeleaf实现表单验证的方法。对于想学习或工作的朋友来说,这是一份很有参考价值的资料。希望对大家有所帮助!

这篇文章主要介绍了Spring Boot 2 Thymeleaf服务器端表单验证实现详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

表单验证分为前端验证和服务器端验证。

服务器端验证方面,Java提供了主要用于数据验证的JSR 303规范,而Hibernate Validator实现了JSR 303规范。

项目依赖加入spring-boot-starter-thymeleaf时,默认就会加入Hibernate Validator的依赖。

开发环境:IntelliJ IDEA 2019.2.2

Spring Boot版本:2.1.8

新建一个名称为demo的Spring Boot项目。

1、pom.xml

<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> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-devtools</artifactId> </dependency>

2、src/main/java/com/example/demo/User.java

Spring Boot 2与Thymeleaf如何实现服务器端表单验证?

package com.example.demo; import org.hibernate.validator.constraints.Length; import javax.validation.constraints.NotBlank; import javax.validation.constraints.Size; public class User { @NotBlank(message = "用户名不能为空") String name; @Length(min = 11, max = 11, message = "手机号长度必须11位") String phone; @Size(min = 6, max = 20, message = "密码长度6-20位") String password; public String getName() { return name; } public void setName(String name) { this.name = name; } public String getPhone() { return phone; } public void setPhone(String phone) { this.phone = phone; } public String getPassword() { return password; } public void setPassword(String password) { this.password = password; } }

3、src/main/java/com/example/demo/FormController.java

package com.example.demo; import org.springframework.stereotype.Controller; import org.springframework.validation.BindingResult; import org.springframework.validation.ObjectError; import org.springframework.web.bind.annotation.ModelAttribute; import org.springframework.web.bind.annotation.PathVariable; import org.springframework.web.bind.annotation.PostMapping; import org.springframework.web.bind.annotation.RequestMapping; import javax.validation.Valid; import java.util.List; @Controller public class FormController { @RequestMapping("/{form}") public String form(@PathVariable String form, @ModelAttribute User user){ return form; } @PostMapping("/submit") public String submit(@Valid User user, BindingResult result){ if (result.hasErrors()) { List<ObjectError> list = result.getAllErrors(); for (ObjectError error : list) { System.out.println(error.getDefaultMessage()); } return "form"; } //业务逻辑处理 return "form"; } }

4、src/main/resources/templates/form.html

前端通过#fields对象输出错误信息有2种方式,1种是在每个字段后面输出,另1种是全部在一起输出。

<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>表单的提交处理</title> <style> .fieldError{color: red} </style> </head> <body> <form method="post" th:action="@{/submit}" th:object="${user}"> <table> <tr> <td>用户名:</td> <td><input type="text" th:field="*{name}" /> <span class="fieldError" th:if="${#fields.hasErrors('*{name}')}" th:errors="*{name}"></span> </td> </tr> <tr> <td>手机号:</td> <td><input type="text" th:field="*{phone}" /> <span class="fieldError" th:if="${#fields.hasErrors('*{phone}')}" th:errors="*{phone}"></span> </td> </tr> <tr> <td>密码:</td> <td><input type="text" th:field="*{password}" /> <span class="fieldError" th:if="${#fields.hasErrors('*{password}')}" th:errors="*{password}"></span> </td> </tr> <tr> <td colspan="2"> <input type="submit" value="提交" /> <div th:each="err : ${#fields.errors('*')}"> <span th:text="${err}" class="fieldError"></span> </div> </td> </tr> </table> </form> </body> </html>

启动服务后,浏览器访问localhost:8080/form,点击提交按钮,结果如下:

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持自由互联。

本文共计1315个文字,预计阅读时间需要6分钟。

Spring Boot 2与Thymeleaf如何实现服务器端表单验证?

这篇文章主要介绍了Spring Boot 2与Thymeleaf服务端表单验证的实现,内容详尽,通过示例代码展示了操作过程。对于想学习或工作的朋友来说,这是一份很有参考价值的资料。需要的朋友可以参考以下内容:

表单验证

Spring Boot 2结合Thymeleaf实现表单验证,可以通过以下步骤进行:

1. 添加依赖:在`pom.xml`中添加Spring Boot和Thymeleaf的依赖。

2.创建表单页面:使用Thymeleaf模板引擎创建表单页面,并使用`th:field`标签绑定表单元素。

3.编写验证逻辑:在控制器中,通过`@Valid`注解标记接收表单数据的实体类,并使用`@Valid`注解标记表单提交的方法。

4.自定义验证器:如果需要自定义验证规则,可以创建一个实现了`Validator`接口的类,并在控制器中注入该验证器。

示例代码

以下是一个简单的示例,展示了如何使用Spring Boot 2和Thymeleaf实现表单验证:

java

// 表单实体类public class User { private String name; private String email;

// 省略getter和setter方法}

// 控制器@Controllerpublic class UserController { @Autowired private UserValidator userValidator;

@GetMapping(/register) public String showRegisterForm(Model model) { model.addAttribute(user, new User()); return register; }

@PostMapping(/register) public String registerUser(@Valid @ModelAttribute(user) User user, BindingResult bindingResult) { if (bindingResult.hasErrors()) { return register; } // 处理注册逻辑 return success; }}

// 自定义验证器public class UserValidator implements Validator { @Override public boolean supports(Class clazz) { return User.class.equals(clazz); }

@Override public void validate(Object target, Errors errors) { User user=(User) target; if (user.getName()==null || user.getName().isEmpty()) { errors.rejectValue(name, required, Name is required); } if (user.getEmail()==null || user.getEmail().isEmpty()) { errors.rejectValue(email, required, Email is required); } // 其他验证规则... }}

总结

通过以上内容,我们可以了解到Spring Boot 2与Thymeleaf实现表单验证的方法。对于想学习或工作的朋友来说,这是一份很有参考价值的资料。希望对大家有所帮助!

这篇文章主要介绍了Spring Boot 2 Thymeleaf服务器端表单验证实现详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

表单验证分为前端验证和服务器端验证。

服务器端验证方面,Java提供了主要用于数据验证的JSR 303规范,而Hibernate Validator实现了JSR 303规范。

项目依赖加入spring-boot-starter-thymeleaf时,默认就会加入Hibernate Validator的依赖。

开发环境:IntelliJ IDEA 2019.2.2

Spring Boot版本:2.1.8

新建一个名称为demo的Spring Boot项目。

1、pom.xml

<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> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-devtools</artifactId> </dependency>

2、src/main/java/com/example/demo/User.java

Spring Boot 2与Thymeleaf如何实现服务器端表单验证?

package com.example.demo; import org.hibernate.validator.constraints.Length; import javax.validation.constraints.NotBlank; import javax.validation.constraints.Size; public class User { @NotBlank(message = "用户名不能为空") String name; @Length(min = 11, max = 11, message = "手机号长度必须11位") String phone; @Size(min = 6, max = 20, message = "密码长度6-20位") String password; public String getName() { return name; } public void setName(String name) { this.name = name; } public String getPhone() { return phone; } public void setPhone(String phone) { this.phone = phone; } public String getPassword() { return password; } public void setPassword(String password) { this.password = password; } }

3、src/main/java/com/example/demo/FormController.java

package com.example.demo; import org.springframework.stereotype.Controller; import org.springframework.validation.BindingResult; import org.springframework.validation.ObjectError; import org.springframework.web.bind.annotation.ModelAttribute; import org.springframework.web.bind.annotation.PathVariable; import org.springframework.web.bind.annotation.PostMapping; import org.springframework.web.bind.annotation.RequestMapping; import javax.validation.Valid; import java.util.List; @Controller public class FormController { @RequestMapping("/{form}") public String form(@PathVariable String form, @ModelAttribute User user){ return form; } @PostMapping("/submit") public String submit(@Valid User user, BindingResult result){ if (result.hasErrors()) { List<ObjectError> list = result.getAllErrors(); for (ObjectError error : list) { System.out.println(error.getDefaultMessage()); } return "form"; } //业务逻辑处理 return "form"; } }

4、src/main/resources/templates/form.html

前端通过#fields对象输出错误信息有2种方式,1种是在每个字段后面输出,另1种是全部在一起输出。

<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>表单的提交处理</title> <style> .fieldError{color: red} </style> </head> <body> <form method="post" th:action="@{/submit}" th:object="${user}"> <table> <tr> <td>用户名:</td> <td><input type="text" th:field="*{name}" /> <span class="fieldError" th:if="${#fields.hasErrors('*{name}')}" th:errors="*{name}"></span> </td> </tr> <tr> <td>手机号:</td> <td><input type="text" th:field="*{phone}" /> <span class="fieldError" th:if="${#fields.hasErrors('*{phone}')}" th:errors="*{phone}"></span> </td> </tr> <tr> <td>密码:</td> <td><input type="text" th:field="*{password}" /> <span class="fieldError" th:if="${#fields.hasErrors('*{password}')}" th:errors="*{password}"></span> </td> </tr> <tr> <td colspan="2"> <input type="submit" value="提交" /> <div th:each="err : ${#fields.errors('*')}"> <span th:text="${err}" class="fieldError"></span> </div> </td> </tr> </table> </form> </body> </html>

启动服务后,浏览器访问localhost:8080/form,点击提交按钮,结果如下:

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持自由互联。