Spring Boot 2 Thymeleafサーバ端末のフォーム検証が詳細な解を実現しました。
この文章は主にSpring Boot 2 Thymeleafサーバー端末のフォーム検証を紹介しています。ここではサンプルコードで紹介されています。非常に詳しくて、皆さんの学習や仕事に対して一定の参考学習価値があります。必要な友達は参考にしてください。
フォームの検証は、フロントエンド認証とサーバ端認証に分けられます。
サーバー側検証では、Javaは主にデータ検証のためのJSR 303仕様を提供し、Hibernate ValidatorはJSR 303仕様を実現した。
プロジェクトがスプリング-book-starter-thymeleafに依存している場合、デフォルトではハイスコアValidatorの依存が加わります。
開発環境:IntelliJ IDEA 209.2.2
Spring Bootバージョン:2.18
demoという名前のSpring Bootプロジェクトを新設します。
1、pom.xml
フロントエンドが菗fieldsのオブジェクトを通してエラー情報を出力する方法は2つあります。1つはフィールドごとに後に出力し、もう1つは全部一緒に出力します。
以上が本文の全部です。皆さんの勉強に役に立つように、私たちを応援してください。
フォームの検証は、フロントエンド認証とサーバ端認証に分けられます。
サーバー側検証では、Javaは主にデータ検証のためのJSR 303仕様を提供し、Hibernate ValidatorはJSR 303仕様を実現した。
プロジェクトがスプリング-book-starter-thymeleafに依存している場合、デフォルトではハイスコアValidatorの依存が加わります。
開発環境:IntelliJ IDEA 209.2.2
Spring Bootバージョン:2.18
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/resource/templates/form.フロントエンドが菗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提出ボタンをクリックして、結果は以下の通りです。以上が本文の全部です。皆さんの勉強に役に立つように、私たちを応援してください。