bl双性强迫侵犯h_国产在线观看人成激情视频_蜜芽188_被诱拐的少孩全彩啪啪漫画

如何使用SpringBoot2Thymeleaf實現服務器端表單驗證

這篇文章主要介紹如何使用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

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,點擊提交按鈕,結果如下:

如何使用Spring Boot 2 Thymeleaf實現服務器端表單驗證

以上是“如何使用Spring Boot 2 Thymeleaf實現服務器端表單驗證”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注創新互聯行業資訊頻道!

當前標題:如何使用SpringBoot2Thymeleaf實現服務器端表單驗證
路徑分享:http://vcdvsql.cn/article14/jhehde.html

成都網站建設公司_創新互聯,為您提供虛擬主機品牌網站設計網站維護網站策劃服務器托管小程序開發

廣告

聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

外貿網站制作