0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

簡述Spring Boot數(shù)據(jù)校驗(yàn)

jf_78858299 ? 來源:QStack ? 作者:月下西樓 ? 2023-03-17 15:07 ? 次閱讀

上一篇文章我們了解了Spring Boot Web相關(guān)的知識(shí),初步了解了spring-boot-starter-web,還了解了@Contrler和@RestController的差別,如果使用@Controller注解只返回?cái)?shù)據(jù)則需要使用@ResponseBody注解。與此同時(shí)還了解了@RequestMapping注解與URL映射,URL映射可以分為URL路徑匹配、Method匹配、consumes和produces匹配、params和header匹配。這篇文章我們將會(huì)介紹數(shù)據(jù)校驗(yàn),對于任何應(yīng)用系統(tǒng)而言,任何客戶端傳入的數(shù)據(jù)都不是絕對安全有效的,這就要求我們在服務(wù)端接收到數(shù)據(jù)時(shí)需要對傳入的數(shù)據(jù)的有效性進(jìn)行驗(yàn)證,以確保傳入的數(shù)據(jù)安全正確。

Hibernate Validator簡介

目前數(shù)據(jù)校驗(yàn)的規(guī)范和組件有很多,Spring Boot默認(rèn)使用的數(shù)據(jù)校驗(yàn)組件是基于JSR數(shù)據(jù)校驗(yàn)規(guī)范的Hibernate Validator,其中常用的注解如下表所示

注解 作用目標(biāo) 檢查規(guī)則
@NotNull 屬性 檢查值是否為空
@Null 屬性 檢查值必須為空
@AsserFalse 屬性 檢查演算結(jié)果是否為false
@AssertTrue 屬性 檢查演算結(jié)果是否為true
@Max(value=) 屬性(以numeric或string類型表示一個(gè)數(shù)字) 檢查值是否小于或等于最大值
@Min(value=) 屬性(以numeric或string類型表示一個(gè)數(shù)字) 檢查值是否大于或等于最小值
@Size(min=, max=) 屬性(array,collection,map) 檢查元素大小是否在最大值和最小值之間(包括臨界值)
@Digits(integer,fraction) 屬性 檢查元素必須是數(shù)字且在范圍內(nèi)
@Past 屬性(data或calender) 檢查日期是否是過去的日期
@Feature 屬性data或calender) 檢查日期是否是未來的日期
@Pattern(regex="rexgex",flag=) 屬性 檢查值是否與正則表達(dá)式匹配
@Range(min=,max=) 屬性(以numeric或string類型表示一個(gè)數(shù)字) 檢查元素大小是否在最大值和最小值之間(包括臨界值)
@Length(min=,max=) 屬性(String) 檢查字符串長度是否符合范圍
@Email 屬性(String) 檢查是否是有效的Email地址
@NotEmpty 屬性(String) 檢查字符串不能為空

使用Hibernate Validator校驗(yàn)數(shù)據(jù)需要定義一個(gè)接受的數(shù)據(jù)模型,使用注解的形式描述字段的校驗(yàn)規(guī)則,下面以User對象為例說明如何校驗(yàn)數(shù)據(jù),先加入以下依賴:

<dependency>
    <groupId>org.springframework.boot<span class="hljs-name"groupId>
    <artifactId>spring-boot-starter-validation<span class="hljs-name"artifactId>
<span class="hljs-name"dependency>

JavaBean參數(shù)校驗(yàn)

Post請求參數(shù)較多時(shí)可以在對應(yīng)的數(shù)據(jù)模型(Java Bean)中進(jìn)行校驗(yàn),通過注解來指定字段校驗(yàn)的規(guī)則。

public class User {

    @NotBlank(message = "姓名不允許為空")
    @Length(min = 2, max = 10, message = "姓名長度錯(cuò)誤,姓名長度2-10")
    private String Name;
    
    @NotNull(message = "年齡不能為空!")
    @Min(18)
    private int age;
    
    @NotBlank(message = "地址不能為空!")
    private String address;
    
    @Email(message = "郵箱格式錯(cuò)誤")
    private String email;
    
    //省略get和set方法
}

上述例子中,每個(gè)message是數(shù)據(jù)校驗(yàn)不通過時(shí)要給出的提示信息。然后需要添加數(shù)據(jù)校驗(yàn)方法。

@PostMapping(path = "/check")
public String check(@RequestBody @Valid User user, BindingResult result) {
    String name = user.getName();
    if (result.hasErrors()) {
        List

上面例子中BindingResult是驗(yàn)證不通過的結(jié)果集合,必須跟在被校驗(yàn)參數(shù)后,若被校驗(yàn)參數(shù)之后沒有BindingResult則會(huì)拋出BindException異常。

JavaBean對象的級(jí)聯(lián)校驗(yàn)

在對象的普通屬性上我們可以直接使用注解進(jìn)行數(shù)據(jù)校驗(yàn),對于關(guān)聯(lián)對象也很容易,在關(guān)聯(lián)對象上添加@Valid注解,關(guān)聯(lián)對象內(nèi)部可以正常使用數(shù)據(jù)校驗(yàn)注解。代碼如下:

public class User {

    @NotBlank(message = "姓名不允許為空")
    @Length(min = 2, max = 10, message = "姓名長度錯(cuò)誤,姓名長度2-10")
    private String Name;

    @NotNull(message = "年齡不能為空!")
    @Min(18)
    private int age;

    @NotBlank(message = "地址不能為空!")
    private String address;

    @Email(message = "郵箱格式錯(cuò)誤")
    private String email;

    @NotNull(message = "detail不能為空")
    @Valid
    private UserDetail detail;
    //省略get和set方法
}
public class UserDetail {

    @NotNull(message = "id不能為空")
    private String id;

    public String getId() {
        return id;
    }

    public void setId(String id) {
        this.id = id;
    }
}

分組校驗(yàn)

在不同的情況下,可能對相同javaBean對象的數(shù)據(jù)校驗(yàn)規(guī)則有所不同,有時(shí)需要根據(jù)狀態(tài)數(shù)據(jù)對javaBean中的某些屬性字段進(jìn)行單獨(dú)驗(yàn)證。這時(shí)候就可以使用分組校驗(yàn)功能,即根據(jù)狀態(tài)啟用一組約束,Hibernate Validator的注解提供了groups參數(shù)用于指定分組,如果沒有指定groups參數(shù),則默認(rèn)屬于javax.validation.groups.Default。接下來我們舉例來說明這一過程。

首先創(chuàng)建分組GroupA和GroupB如下,這兩個(gè)接口作為兩個(gè)校驗(yàn)規(guī)則的分組。

public interface GroupA {
}
public interface GroupB {
}

然后創(chuàng)建實(shí)體類Person,并在相關(guān)字段定義分組校驗(yàn)規(guī)則。

public class Person {

    @NotBlank(message = "userId不能為空", groups = {GroupA.class})
    private String userId;

    @NotBlank(message = "用戶名不能為空", groups = {GroupB.class})
    private String name;

    @Range(min=20, max = 30, message = "年齡必須在【20,30】", groups = {GroupA.class})
    @Range(min = 30, max = 40, message = "年齡必須在【30,40】", groups = {GroupB.class})
    private int age;

   //省略來get方法和set方法
}

上述例子中,在age字段使用了兩個(gè)校驗(yàn)規(guī)則,GroupA年齡要在20-30,GroupB年齡要在30-40。最后使用分組:

@RequestMapping("/save")
public String save(@RequestBody @Validated({ GroupA.class, Default.class}) Person person, BindingResult result) {
    if (result.hasErrors()) {
        List

其中@Validated注解中增加了{(lán)GroupA.class, Default.class}參數(shù)表示對于定義了分組校驗(yàn)規(guī)則的字段使用GroupA規(guī)則,其他使用默認(rèn)規(guī)則。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報(bào)投訴
  • Web
    Web
    +關(guān)注

    關(guān)注

    2

    文章

    1254

    瀏覽量

    69202
  • URL
    URL
    +關(guān)注

    關(guān)注

    0

    文章

    138

    瀏覽量

    15271
  • spring
    +關(guān)注

    關(guān)注

    0

    文章

    335

    瀏覽量

    14277
  • 服務(wù)端
    +關(guān)注

    關(guān)注

    0

    文章

    66

    瀏覽量

    6958
收藏 人收藏

    評論

    相關(guān)推薦

    Spring Boot如何實(shí)現(xiàn)異步任務(wù)

    Spring Boot 提供了多種方式來實(shí)現(xiàn)異步任務(wù),這里介紹三種主要實(shí)現(xiàn)方式。 1、基于注解 @Async @Async 注解是 Spring 提供的一種輕量級(jí)異步方法實(shí)現(xiàn)方式,它可以標(biāo)記在方法上
    的頭像 發(fā)表于 09-30 10:32 ?1315次閱讀

    Spring Boot Starter需要些什么

    pulsar-spring-boot-starter是非常有必要的,在此之前,我們先看看一個(gè)starter需要些什么。 Spring Boot Starter spring-boot
    的頭像 發(fā)表于 09-25 11:35 ?687次閱讀
    <b class='flag-5'>Spring</b> <b class='flag-5'>Boot</b> Starter需要些什么

    啟動(dòng)Spring Boot項(xiàng)目應(yīng)用的三種方法

    微服務(wù)!據(jù)谷歌搜索調(diào)查數(shù)據(jù)顯示,spring boot將成為新一代框架。所以從事javaee開發(fā)的小伙伴,學(xué)好spring boot是非常有
    發(fā)表于 01-14 17:33

    Spring Boot從零入門1 詳述

    在開始學(xué)習(xí)Spring Boot之前,我之前從未接觸過Spring相關(guān)的項(xiàng)目,Java基礎(chǔ)還是幾年前自學(xué)的,現(xiàn)在估計(jì)也忘得差不多了吧,寫Spring
    的頭像 發(fā)表于 12-10 22:18 ?573次閱讀

    Spring Boot實(shí)現(xiàn)各種參數(shù)校驗(yàn)

    之前也寫過一篇關(guān)于Spring Validation使用的文章,不過自我感覺還是浮于表面,本次打算徹底搞懂Spring Validation。本文會(huì)詳細(xì)介紹Spring Validation各種場景下的最佳實(shí)踐及其實(shí)現(xiàn)原理,死磕
    的頭像 發(fā)表于 08-14 15:54 ?906次閱讀

    Spring Boot特有的實(shí)踐

    Spring Boot是最流行的用于開發(fā)微服務(wù)的Java框架。在本文中,我將與你分享自2016年以來我在專業(yè)開發(fā)中使用Spring Boot所采用的最佳實(shí)踐。這些內(nèi)容是基于我的個(gè)人經(jīng)驗(yàn)
    的頭像 發(fā)表于 09-29 10:24 ?843次閱讀

    強(qiáng)大的Spring Boot 3.0要來了

    來源:OSC開源社區(qū)(ID:oschina2013) Spring Boot 3.0 首個(gè) RC 已發(fā)布,此外還為兩個(gè)分支發(fā)布了更新:2.7.5 2.6.13。 3.0.0-RC1: https
    的頭像 發(fā)表于 10-31 11:17 ?1557次閱讀

    Spring Boot Web相關(guān)的基礎(chǔ)知識(shí)

    Boot的第一個(gè)接口。接下來將會(huì)將會(huì)介紹使用Spring Boot開發(fā)Web應(yīng)用的相關(guān)內(nèi)容,其主要包括使用spring-boot-starter-web組件來實(shí)現(xiàn)Web應(yīng)用開發(fā)、UR
    的頭像 發(fā)表于 03-17 15:03 ?592次閱讀

    Spring Boot應(yīng)用中如何做好參數(shù)校驗(yàn)?

    參數(shù)驗(yàn)證很重要,是平時(shí)開發(fā)環(huán)節(jié)中不可少的一部分,但是我想很多后端同事會(huì)偷懶,干脆不錯(cuò),這樣很可能給系統(tǒng)的穩(wěn)定性和安全性帶來嚴(yán)重的危害。那么在Spring Boot應(yīng)用中如何做好參數(shù)校驗(yàn)工作呢,本文提供了10個(gè)小技巧,你知道幾個(gè)呢
    的頭像 發(fā)表于 05-11 10:52 ?698次閱讀

    Spring Boot應(yīng)用中如何做好參數(shù)校驗(yàn)?2

    參數(shù)驗(yàn)證很重要,是平時(shí)開發(fā)環(huán)節(jié)中不可少的一部分,但是我想很多后端同事會(huì)偷懶,干脆不錯(cuò),這樣很可能給系統(tǒng)的穩(wěn)定性和安全性帶來嚴(yán)重的危害。那么在Spring Boot應(yīng)用中如何做好參數(shù)校驗(yàn)工作呢,本文提供了10個(gè)小技巧,你知道幾個(gè)呢
    的頭像 發(fā)表于 05-11 10:56 ?458次閱讀

    Spring Boot如何優(yōu)雅實(shí)現(xiàn)數(shù)據(jù)加密存儲(chǔ)、模糊匹配和脫敏

    近來我們都在圍繞著使用Spring Boot開發(fā)業(yè)務(wù)系統(tǒng)時(shí)如何保證數(shù)據(jù)安全性這個(gè)主題展開總結(jié),當(dāng)下大部分的B/S架構(gòu)的系統(tǒng)也都是基于Spring B
    的頭像 發(fā)表于 06-19 14:42 ?1788次閱讀
    <b class='flag-5'>Spring</b> <b class='flag-5'>Boot</b>如何優(yōu)雅實(shí)現(xiàn)<b class='flag-5'>數(shù)據(jù)</b>加密存儲(chǔ)、模糊匹配和脫敏

    Spring Boot Actuator快速入門

    不知道大家在寫 Spring Boot 項(xiàng)目的過程中,使用過 Spring Boot Actuator 嗎?知道 Spring
    的頭像 發(fā)表于 10-09 17:11 ?572次閱讀

    Spring Boot啟動(dòng) Eureka流程

    在上篇中已經(jīng)說過了 Eureka-Server 本質(zhì)上是一個(gè) web 應(yīng)用的項(xiàng)目,今天就來看看 Spring Boot 是怎么啟動(dòng) Eureka 的。 Spring Boot 啟動(dòng) E
    的頭像 發(fā)表于 10-10 11:40 ?785次閱讀
    <b class='flag-5'>Spring</b> <b class='flag-5'>Boot</b>啟動(dòng) Eureka流程

    Spring Boot的啟動(dòng)原理

    可能很多初學(xué)者會(huì)比較困惑,Spring Boot 是如何做到將應(yīng)用代碼和所有的依賴打包成一個(gè)獨(dú)立的 Jar 包,因?yàn)閭鹘y(tǒng)的 Java 項(xiàng)目打包成 Jar 包之后,需要通過 -classpath 屬性
    的頭像 發(fā)表于 10-13 11:44 ?581次閱讀
    <b class='flag-5'>Spring</b> <b class='flag-5'>Boot</b>的啟動(dòng)原理

    Spring Boot 的設(shè)計(jì)目標(biāo)

    什么是Spring Boot Spring BootSpring 開源組織下的一個(gè)子項(xiàng)目,也是 S
    的頭像 發(fā)表于 10-13 14:56 ?520次閱讀
    <b class='flag-5'>Spring</b> <b class='flag-5'>Boot</b> 的設(shè)計(jì)目標(biāo)