1. <strong id="7actg"></strong>
    2. <table id="7actg"></table>

    3. <address id="7actg"></address>
      <address id="7actg"></address>
      1. <object id="7actg"><tt id="7actg"></tt></object>

        Springboot中如何做參數(shù)校驗

        共 4845字,需瀏覽 10分鐘

         ·

        2021-07-13 07:43

        來源:juejin.cn/post/6913735652806754311

        前段時間提交代碼審核,同事提了一個代碼規(guī)范缺陷:參數(shù)校驗應(yīng)該放在controller層。到底應(yīng)該如何做參數(shù)校驗?zāi)?/p>

        Controller層 VS Service層

        去網(wǎng)上查閱了一些資料,一般推薦與業(yè)務(wù)無關(guān)的放在Controller層中進行校驗,而與業(yè)務(wù)有關(guān)的放在Service層中進行校驗。那么如何將參數(shù)校驗寫的優(yōu)雅美觀呢,如果都是if - else,就感覺代碼寫的很low,還好有輪子可以使用

        常用校驗工具類

        使用Hibernate Validate

        引入依賴

        <dependency>
            <groupId>org.hibernate</groupId>
            <artifactId>hibernate-validator</artifactId>
            <version>4.3.1.Final</version>
        </dependency>

        常用注解說明

        注解說明
        @Length(min=,max=)檢查所屬的字段的長度是否在min和max之間,只能用于字符串
        @Range(min=,max=,message=)被注釋的元素必須在合適的范圍內(nèi)
        @Max該字段的值只能小于或等于該值
        @Min該字段的值只能大于或等于該值
        @NotNull不能為null
        @NotBlank不能為空,檢查時會將空格忽略
        @NotEmpty不能為空,這里的空是指空字符串
        @Pattern(regex=,flag=)被注釋的元素必須符合指定的正則表達式

        使用姿勢需要搭配在Controller中搭配@Validated或@Valid注解一起使用,@Validated和@Valid注解區(qū)別不是很大,一般情況下任選一個即可,區(qū)別如下:

        注解@Validated@Valid
        所屬的包屬于org.springframework.validation.annotation包下的,是spring提供的屬于javax.validation包下,是jdk給提供的
        是否支持分組和排序

        雖然@Validated比@Valid更加強大,在@Valid之上提供了分組功能和驗證排序功能,不過在實際項目中一直沒有用到過 Hibernate-validate框架中的注解是需要加在實體中一起使用的

        • 定義一個實體
        public class DataSetSaveVO {
            //唯一標(biāo)識符為空
            @NotBlank(message = "user uuid is empty")
            //用戶名稱只能是字母和數(shù)字
            @Pattern(regexp = "^[a-z0-9]+$", message = "user names can only be alphabetic and numeric")
            @Length(max = 48, message = "user uuid length over 48 byte")
            private String userUuid;

            //數(shù)據(jù)集名稱只能是字母和數(shù)字
            @Pattern(regexp = "^[A-Za-z0-9]+$", message = "data set names can only be letters and Numbers")
            //文件名稱過長
            @Length(max = 48, message = "file name too long")
            //文件名稱為空
            @NotBlank(message = "file name is empty")
            private String name;

            //數(shù)據(jù)集描述最多為256字節(jié)
            @Length(max = 256, message = "data set description length over 256 byte")
            //數(shù)據(jù)集描述為空
            @NotBlank(message = "data set description is null")
            private String description;
        }

        說明:message字段為不符合校驗規(guī)則時拋出的異常信息

        • Controller層中的方法
        @PostMapping
        public ResponseVO createDataSet(@Valid @RequestBody DataSetSaveVO dataSetVO) {
            return ResponseUtil.success(dataSetService.saveDataSet(dataSetVO));
        }

        說明:在校驗的實體DataSetSaveVO旁邊添加@Valid或@Validated注解

        使用commons-lang3

        引入依賴

        <dependency>
            <groupId>org.apache.commons</groupId>
            <artifactId>commons-lang3</artifactId>
            <version>3.4</version>
        </dependency>

        常用方法說明

        方法說明
        CollectionUtils.isEmpty判斷集合是否為空,為null或者size==0,返回true
        CollectionUtils.isNotEmpty判斷集合是否為非空
        StringUtils.isEmpty判斷字符串是否為空
        StringUtils.isNotEmpty判斷字符串是否非空
        StringUtils.isBlank判斷字符串是否為空,為null或者size==0或者只存在空白字符(如" "),則返回true
        StringUtils.isNotBlank判斷字符串是否為非空
        • 測試代碼
        //StringUtils.isEmpty
        System.out.println(StringUtils.isEmpty(""));  //true
        System.out.println(StringUtils.isEmpty("  "));  //false
        //StringUtils.isNotEmpty
        System.out.println(StringUtils.isNotEmpty(""));  //false

        //StringUtils.isBlank
        System.out.println(StringUtils.isBlank(""));  //true
        System.out.println(StringUtils.isBlank(" "));  //true
        //StringUtils.isNotBlank
        System.out.println(StringUtils.isNotBlank(" "));  //false

        List<Integer> emptyList = new ArrayList<>();
        List<Integer> nullList = null;
        List<Integer> notEmptyList = new ArrayList<>();
        notEmptyList.add(1);

        //CollectionUtils.isEmpty
        System.out.println(CollectionUtils.isEmpty(emptyList));   //true
        System.out.println(CollectionUtils.isEmpty(nullList));   //true
        System.out.println(CollectionUtils.isEmpty(notEmptyList));   //false

        //CollectionUtils.isNotEmpty
        System.out.println(CollectionUtils.isNotEmpty(emptyList));   //false
        System.out.println(CollectionUtils.isNotEmpty(nullList));   //false
        System.out.println(CollectionUtils.isNotEmpty(notEmptyList));   //true

        自定義注解

        當(dāng)上面的方面都無法滿足校驗的需求以后,可以考慮使用自定義注解。

        PS:如果覺得我的分享不錯,歡迎大家隨手點贊、在看。

        瀏覽 66
        點贊
        評論
        收藏
        分享

        手機掃一掃分享

        分享
        舉報
        評論
        圖片
        表情
        推薦
        點贊
        評論
        收藏
        分享

        手機掃一掃分享

        分享
        舉報
        1. <strong id="7actg"></strong>
        2. <table id="7actg"></table>

        3. <address id="7actg"></address>
          <address id="7actg"></address>
          1. <object id="7actg"><tt id="7actg"></tt></object>
            午夜成人福利视频 | 国产一级影片 | 亚洲婷婷丁香五月天 | 久久久久久蜜臀 | 一线天在线 | 18禁无套内射 | 大香蕉伊人在钱 | 干屄视频免费在线观看 | 91国内精品视频 | 日韩色哟哟 |