您好,登錄后才能下訂單哦!
這篇文章主要講解了“BindingResult的使用方法有哪些”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“BindingResult的使用方法有哪些”吧!
記一個簡單又好用的API:BindingResult
BindingResult使用起來很簡單,一般在controller中使用
作用:用于對前端穿進來的參數進行校驗,省去了大量的邏輯判斷操作
@NotEmpty
:用在集合類上面;不能為null,而且長度必須大于0
@NotBlank
:用在String上面;只能作用在String上,不能為null,而且調用trim()后,長度必須大于0
@NotNull
:用在基本類型上;不能為null,但可以為empty。
@Size(min=,max=)
:驗證對象(Array,Collection,Map,String)長度是否在給定的范圍之內 不要錯用了異常類型,比如在int上不可用@size
@Length(min=, max=)
:只適用于String 類型
@AssertTrue
:驗證 Boolean 對象是否為 true
@AssertFalse
:驗證 Boolean 對象是否為 false
@Past
:驗證 Date 和 Calendar 對象是否在當前時間之前
@Future
:驗證 Date 和 Calendar 對象是否在當前時間之后
@Pattern
:驗證 String 對象是否符合正則表達式的規則
@Vaild
遞歸驗證,用于對象、數組和集合,會對對象的元素、數組的元素進行一一校驗
@Email
用于驗證一個字符串是否是一個合法的右鍵地址,空字符串或null算驗證通過
@URL(protocol=,host=,port=,regexp=,flags=)
用于校驗一個字符串是否是合法URL
建議使用在Stirng,Integer類型,不建議使用在int類型上,因為表單值為"" 時無法轉換為int,但可以轉換為Stirng為"",Integer為null
@Min
:驗證 Number 和 String 對象是否大等于指定的值
@Max
:驗證 Number 和 String 對象是否小等于指定的值
@DecimalMax
:被標注的值必須不大于約束中指定的最大值. 這個約束的參數是一個通過BigDecimal定義的最大值的字符串表示.小數存在精度
@DecimalMin
:被標注的值必須不小于約束中指定的最小值. 這個約束的參數是一個通過BigDecimal定義的最小值的字符串表示.小數存在精度
@Digits
:驗證 Number 和 String 的構成是否合法
@Digits(integer=,fraction=)
:驗證字符串是否是符合指定格式的數字,interger指定整數精度,fraction指定小數精度。
一開始傳入的參數沒有使用@Validated 修飾,結果綁定不起作用,參數校驗不成功,加上此注解即可生效。
所以BingdingResult是要與@Validated同時使用的。
項目中具體使用如下:
controller中:
@ApiOperation("添加角色") @RequestMapping(value = "/create", method = RequestMethod.POST) @ResponseBody public CommonResult create(@Validated @RequestBody UmsRole role, BindingResult bindingResult ) { int count = roleService.create(role); if (count > 0) { return CommonResult.success(count); } return CommonResult.failed(); }
domain中:
import io.swagger.annotations.ApiModelProperty; import javax.validation.constraints.NotEmpty; import java.io.Serializable; import java.util.Date; @Data public class UmsRole implements Serializable { private Long id; @ApiModelProperty(value = "名稱") @NotEmpty(message = "name不能為空!") private String name; @ApiModelProperty(value = "描述") @NotEmpty(message = "描述不能為空!") private String description; @ApiModelProperty(value = "后臺用戶數量") private Integer adminCount; @ApiModelProperty(value = "創建時間") private Date createTime; @ApiModelProperty(value = "啟用狀態:0->禁用;1->啟用") private Integer status; private Integer sort; private static final long serialVersionUID = 1L;
調用接口返回效果:
參數:
{
“name”:“test”
}
返回值:
{
“code”: 404,
“message”: “描述不能為空!”,
“data”: null
}
注意!
1.@Validated 與BindingResult 需要相鄰,否則 變量result 不能接受錯誤信息
控制臺輸出
Field error in object 'entity' on field '變量': rejected value [null]; codes [NotNull.entity.變量,NotNull.變量,NotNull.java.lang.String,NotNull]; arguments [org.springframework.context.support.DefaultMessageSourceResolvable: codes
2.如果使用了@Validated,那么BeanValidate也會拋出異常而不是之前的封裝在BindingResult中
總結:
使用BindingResult,省去了代碼塊中的大部分校驗
controller代碼
@RequestMapping("") public String index(@Valid User user , BindingResult bindingResult){ if (bindingResult.hasErrors()){ List<ObjectError> allErrors = bindingResult.getAllErrors(); ObjectError objectError = allErrors.get(0); System.out.println(objectError.getDefaultMessage()); System.out.println(objectError.getObjectName()); System.out.println(allErrors); } return "index"; }
請求先來到DispatcherServlet的doDispatch 方法,最終會調用ModelAttributeMethodProcessor#resolveArgument方法
調用DataBinder#validate方法后調用ConstraintTree#validateSingleConstraint,由它來調用具體的驗證器
具體的驗證器
感謝各位的閱讀,以上就是“BindingResult的使用方法有哪些”的內容了,經過本文的學習后,相信大家對BindingResult的使用方法有哪些這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。