天天看點

Springboot背景驗證參數[email protected]注解使用

pom檔案引入依賴:

<dependency>
    <groupId>org.hibernate</groupId>
    <artifactId>hibernate-validator</artifactId>
</dependency>      

VO 頁面資料添加注解,傳過來的資料進行校驗。

/**
 * 個人使用者 --展示對象 -- 注冊
 * @author wly
 */
public class SavePersonUserVO {

    private long id;

    @NotBlank
    private String personName;

    @Min(0)
    @Max(1)
    @NotNull
    private int sex;

    @Min(1)
    @Max(4)
    @NotNull
    private int licenseType;

    @NotBlank
    private String licenseNumber;

    @NotBlank
    private String telNumber;

    @NotBlank
    private String address;

    @NotBlank
    private String email;
    
    //get、set方法

    //toString 方法
}
           

 Controller層使用@Valid注解, bindResult為出錯資料

public Object savePersonUser(@Valid @RequestBody SavePersonUserVO savePersonUserVO, BindingResult bindResult, HttpServletResponse resp) {
        logger.info("PersonUserController.savePersonUser>>>>>>personUserInfoVO:" + savePersonUserVO);
        if (savePersonUserVO == null) {
            return ErrorEnum.ILLEGAL_REQUEST_PARAMETER.resp(resp);
        }
        Result result = new Result();
        if (bindResult.hasErrors()) {
            if (logger.isWarnEnabled()) {
                StringBuilder content = new StringBuilder();
                for (FieldError item : bindResult.getFieldErrors()) {
                    content.append(item.getField()).append("=").append(item.getDefaultMessage()).append(",");
                }
                logger.info("個人使用者注冊時請求參數非法,原因:[{}]", content.substring(0, content.length() - 1));
            }
            return ErrorEnum.ILLEGAL_REQUEST_PARAMETER.resp(resp);
        }

      
        // ...  ...

        result.setInfo(true);
        logger.info("PersonUserController.savePersonUser>>>>>>result:" + JsonUtils.object2Json(result));
        return result;
    }
           

postMan測試:

Springboot背景驗證參數[email protected]注解使用

VO層注解總結:

@Null  被注釋的元素必須為null

@NotNull  被注釋的元素不能為null

@AssertTrue  被注釋的元素必須為true

@AssertFalse  被注釋的元素必須為false

@Min(value)  被注釋的元素必須是一個數字,其值必須大于等于指定的最小值

@Max(value)  被注釋的元素必須是一個數字,其值必須小于等于指定的最大值

@DecimalMin(value)  被注釋的元素必須是一個數字,其值必須大于等于指定的最小值

@DecimalMax(value)  被注釋的元素必須是一個數字,其值必須小于等于指定的最大值

@Size(max,min)  被注釋的元素的大小必須在指定的範圍内。

@Digits(integer,fraction)  被注釋的元素必須是一個數字,其值必須在可接受的範圍内

@Past  被注釋的元素必須是一個過去的日期

@Future  被注釋的元素必須是一個将來的日期

@Pattern(value) 被注釋的元素必須符合指定的正規表達式。

@Email 被注釋的元素必須是電子郵件位址

@Length 被注釋的字元串的大小必須在指定的範圍内

@NotEmpty  被注釋的字元串必須非空

@Range  被注釋的元素必須在合适的範圍内