Spring Boot 2 + Thymeleaf:服务器端表单验证
2019-10-25 06:48:06来源:博客园 阅读 ()
表单验证分为前端验证和服务器端验证。
服务器端验证方面,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
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>
启动服务后,浏览器访问http://localhost:8080/form,点击提交按钮,结果如下:
原文链接:https://www.cnblogs.com/gdjlc/p/11717023.html
如有疑问请与原作者联系
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
上一篇:java里的单例实现
- Spring系列.ApplicationContext接口 2020-06-11
- springboot2配置JavaMelody与springMVC配置JavaMelody 2020-06-11
- 给你一份超详细 Spring Boot 知识清单 2020-06-11
- SpringBoot 2.3 整合最新版 ShardingJdbc + Druid + MyBatis 2020-06-11
- 掌握SpringBoot-2.3的容器探针:实战篇 2020-06-11
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash