SpringBoot 2 快速整合 | Hibernate Validator 數據校驗

来源:https://www.cnblogs.com/jerry126/archive/2019/09/17/11531317.html
-Advertisement-
Play Games

概述 在開發RESTFull API 和普通的表單提交都需要對用戶提交的數據進行校驗,例如:用戶姓名不能為空,年齡必須大於0 等等。這裡我們主要說的是後臺的校驗,在 SpringBoot 中我們可以通過使用 Hibernate Validator 來進行後臺的數據校驗的。 閑話少說!接下來就開始介紹 ...


概述

在開發RESTFull API 和普通的表單提交都需要對用戶提交的數據進行校驗,例如:用戶姓名不能為空,年齡必須大於0 等等。這裡我們主要說的是後臺的校驗,在 SpringBoot 中我們可以通過使用 Hibernate Validator 來進行後臺的數據校驗的。

閑話少說!接下來就開始介紹如何使用 Hibernate Validator 來進行數據的校驗。

Hibernate Validator 實戰操作

我們在添加用戶的功能基礎上來進行改造。

用戶Model類代碼如下:

public class User {
    private String name;
    private Integer age;
    //省略get and set 方法
}

用戶Controller代碼如下:
java @RequestMapping(value = "",method = RequestMethod.POST) public void add(User user){ log.info("添加用戶成功:"+"name:{},age:{}",user.getName(),user.getAge()); }

第一步我們先在 User 類上添加校驗的註解,具體代碼如下:

public class User {
  @NotEmpty(message="請輸入您的名稱!")
  private String name;
  @Max(value = 100, message = "年齡必須在20-100之間!")
  @Min(value= 20 ,message= "年齡必須在20-100之間!" )
  private Integer age;
  ..省略get 和set 方法
}

我們來大致說明一下 註解的含義:

  • 註解中message : 如果欄位信息和檢驗規則不符合提示的錯誤信息。
  • 註解中的value: 表示欄位信息限定的值。
  • @NotEmpty : 表示name 變數不能為空。
  • @Max: 表示年齡的最大值是多少。
  • @Min: 表示年齡的最小值是多少。

第二步就是對用戶添加方法進行改造

用戶添加方法中的 User 參數需要聲明 @Valid 註解,添加該註解主要是指定要校驗的參數實例,然後在添加用戶方法中添加 BindingResult 參數。
BindingResult:主要是存儲校驗結果的數據,我們可以通過 BindingResult 來判斷校驗是否通過和獲取校驗錯誤提示信息。

具體代碼如下:
java @PostMapping() public User add(@Valid User user,BindingResult bindingResult){ if(bindingResult.hasErrors()) { String defaultMessage = bindingResult.getFieldError().getDefaultMessage(); System.out.println(defaultMessage); return null; } log.info("springboot添加用戶成功:"+"name:{},age:{}",user.getName(),user.getAge()); return user; }

測試:

這裡測試使用的是谷歌的一個插件工具:Advanced REST client 來完成的,你也可以選擇你順手的工具進行測試。

測試用戶名稱為空的情況:
圖片
後臺日誌輸出如下:
圖片
測試年齡不在20到100 的數據 :
圖片
後臺日誌輸出如下:
圖片

Hibernate Validator詳細介紹

Hibernate Validator 是 實現JSR349的校驗框架,他預設提供已經定義好的校驗註解,我們經常使用的大致如下:

  • @NotNull: 校驗欄位是否為空
  • @NotEmpty: 校驗數組集合map是否為空並且元素大於0
  • @Max(value=): 限定指端的最大值
  • @Min(value=): 限定欄位的最小值
  • @Size(min=, max=): 校驗集合map元素數量的範圍
  • @Range(min=, max=): 校驗數組String或者數據區間範圍
  • @Email: 校驗欄位是否是郵箱
  • @Past: 校驗是否是一個過期的日期
  • @NotBlank: 校驗字元串是否非空 即 !=null&& equals("")
  • @Valid: 聲明要校驗數據的類參數

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 在寫pc端頁面時,用swiper插件發現在ie中用不了,百度下說是swiper從3以後向手機端發展,所以在pc端無響應。後來瞭解到,swiper3是專門針對移動端寫的。如果想相容IE8的話,應該引入swiper2. 也就是:idangerous.swiper.js 官網演示地址:http://2.s ...
  • 陰天,在不開燈的房間,當所有思緒都一點一點沉澱,愛情究竟是精神鴉片,還是世紀末的無聊消遣。 ...
  • 效果 效果圖如下,純css實現超酷炫的星級評分動畫效果 ​ ​ 實現思路 dom結構 用form實現 <form> <div class="star"> <input type="radio" id="rate5" name="rating" value="5"> <label for="rate5 ...
  • 效果 效果圖如下 ​ ​ 實現思路 dom結構 用兩個嵌套的div容器就可以了,父容器來控製圖標顯示的位置,子容器用來寫烏雲的樣式。而陰影和閃電的樣式都用偽元素就可以了,這些都是在css中定義的。 <div class="container"> <div class="stormy"></div> ...
  • 場景 Docker-Compose簡介與Ubuntu Server 上安裝Compose: https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/100902301 在上面實現Compose成功安裝的基礎上,使用Compose啟動項目。 ...
  • Compose簡介 Compose是Docker官方的開源項目,負責對Docker容器集群的快速編排。 Compose是定義和運行多個Docker容器的應用。 舉例來說: 一個項目除了Tomcat容器外,還需要mysql服務容器,Compose允許用戶通過一個單獨的 docker-compose.y ...
  • 什麼是常量 用final修飾的成員變數表示常量,值一旦給定就無法改變! final修飾的變數有三種:靜態變數、實例變數和局部變數,分別表示三種類型的常量。 Class文件中的常量池 在Class文件結構中,最頭的4個位元組用於存儲魔數Magic Number,用於確定一個文件是否能被JVM接受,再接著 ...
  • 引言: 原型模式是什麼?它是在什麼場景下被提出的呢?本章節,我們將詳細瞭解下原型模式。 在軟體系統中,當創建一個類的實例過程過於昂貴或複雜,並且我們需要創建多個這樣類的實例時,如果我們通過new來創建類實例,這就會增加創建類的複雜度和創建過程與客戶代碼複雜的耦合度。如果採用工廠模式來創建這樣的實例對 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...