Spring Boot 2 Thymeleaf 서버 쪽 폼 검증 상세 설명

이 글 은 Spring Boot 2 Thymeleaf 서버 쪽 폼 검증 에 대한 상세 한 설명 을 소개 합 니 다.이 글 은 예시 코드 를 통 해 매우 상세 하 게 소개 되 어 있 으 며 여러분 의 학습 이나 업무 에 대해 어느 정도 참고 학습 가치 가 있 으 므 로 필요 한 분 들 은 참고 하 시기 바 랍 니 다.
폼 검증 은 전단 검증 과 서버 단 검증 으로 나 뉜 다.
서버 측 검증 에 있어 자바 는 데이터 검증 에 주로 사용 되 는 JSR 303 규범 을 제 공 했 고,Hibernate Validator 는 JSR 303 규범 을 실현 했다.
프로젝트 가 spring-boot-starter-thymeleaf 에 의존 할 때 기본적으로 Hibernate Validator 에 의존 합 니 다.
개발 환경:IntelliJ IDEA 2019.2.2
Spring Boot 버 전:2.1.8
데모 라 는 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 대상 을 통 해 오류 정 보 를 출력 하 는 두 가지 방법 이 있 습 니 다.하 나 는 필드 마다 출력 되 고 다른 하 나 는 모두 함께 출력 됩 니 다.

<!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,제출 단 추 를 누 르 면 결 과 는 다음 과 같 습 니 다.

이상 이 바로 본 고의 모든 내용 입 니 다.여러분 의 학습 에 도움 이 되 고 저 희 를 많이 응원 해 주 셨 으 면 좋 겠 습 니 다.

좋은 웹페이지 즐겨찾기