這篇文章主要為大家展示了如何使用spring注解驗(yàn)證@NotNull,內(nèi)容簡而易懂,希望大家可以學(xué)習(xí)一下,學(xué)習(xí)完之后肯定會有收獲的,下面讓小編帶大家一起來看看吧。
成都創(chuàng)新互聯(lián)公司專注于成都網(wǎng)站建設(shè)、做網(wǎng)站、網(wǎng)頁設(shè)計、網(wǎng)站制作、網(wǎng)站開發(fā)。公司秉持“客戶至上,用心服務(wù)”的宗旨,從客戶的利益和觀點(diǎn)出發(fā),讓客戶在網(wǎng)絡(luò)營銷中找到自己的駐足之地。尊重和關(guān)懷每一位客戶,用嚴(yán)謹(jǐn)?shù)膽B(tài)度對待客戶,用專業(yè)的服務(wù)創(chuàng)造價值,成為客戶值得信賴的朋友,為客戶解除后顧之憂。
常用標(biāo)簽
@Null 被注釋的元素必須為null
@NotNull 被注釋的元素不能為null
@AssertTrue 被注釋的元素必須為true
@AssertFalse 被注釋的元素必須為false
@Min(value) 被注釋的元素必須是一個數(shù)字,其值必須大于等于指定的最小值
@Max(value) 被注釋的元素必須是一個數(shù)字,其值必須小于等于指定的最大值
@DecimalMin(value) 被注釋的元素必須是一個數(shù)字,其值必須大于等于指定的最小值
@DecimalMax(value) 被注釋的元素必須是一個數(shù)字,其值必須小于等于指定的最大值
@Size(max,min) 被注釋的元素的大小必須在指定的范圍內(nèi)。
@Digits(integer,fraction) 被注釋的元素必須是一個數(shù)字,其值必須在可接受的范圍內(nèi)
@Past 被注釋的元素必須是一個過去的日期
@Future 被注釋的元素必須是一個將來的日期
@Pattern(value) 被注釋的元素必須符合指定的正則表達(dá)式。
@Email 被注釋的元素必須是電子郵件地址
@Length 被注釋的字符串的大小必須在指定的范圍內(nèi)
@NotEmpty 被注釋的字符串必須非空
@Range 被注釋的元素必須在合適的范圍內(nèi)
example :
vo 頁面?zhèn)鬟^來的數(shù)據(jù)進(jìn)行校驗(yàn)
inferface : 只是作為標(biāo)記一個組別 可以在vo驗(yàn)證的某個字段上面加入多個組別,這樣沒有加入的組別就不會驗(yàn)證這個字段
controller: 需要 加入 @Validated (GroupInterface1.class) //GroupInterface1.class
是定義的分組 GroupInterface2.class 需要校驗(yàn)的字段是不會驗(yàn)證的
VO:
public class User implements Serializable { /** * 主鍵 */ @NotNull(message = "primary is not null",groups = {GroupInterface1.class}) private Long id; @Pattern(regexp = "[0123456789]",groups = {GroupInterface1.class,GroupInterface2.class},message = "hava a error Date") private Long maxDiscountAmount; @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss", timezone = "GMT+8") private Date createTime; @Future(message = "expireTime is not less than now",groups = {GroupInterface1.class,GroupInterface2.class}) @NotNull(message = "expireTime is not null",groups = {GroupInterface1.class,GroupInterface2.class}) private Date expireTime; }
另外一個例子:
import java.util.Date; import javax.validation.constraints.DecimalMax; import javax.validation.constraints.DecimalMin; import javax.validation.constraints.Email; import javax.validation.constraints.Future; import javax.validation.constraints.Max; import javax.validation.constraints.Min; import javax.validation.constraints.NotNull; import javax.validation.constraints.Size; import org.hibernate.validator.constraints.Range; import org.springframework.format.annotation.DateTimeFormat; /**** imports ****/ public class ValidatorPojo { // 非空判斷 @NotNull(message = "id不能為空") private Long id; @Future(message = "需要一個將來日期") // 只能是將來的日期 // @Past //只能去過去的日期 @DateTimeFormat(pattern = "yyyy-MM-dd") // 日期格式化轉(zhuǎn)換 @NotNull // 不能為空 private Date date; @NotNull // 不能為空 @DecimalMin(value = "0.1") // 最小值0.1元 @DecimalMax(value = "10000.00") // 最大值10000元 private Double doubleValue = null; @Min(value = 1, message = "最小值為1") // 最小值為1 @Max(value = 88, message = "最大值為88") // 最大值88 @NotNull // 不能為空 private Integer integer; @Range(min = 1, max = 888, message = "范圍為1至888") // 限定范圍 private Long range; // 郵箱驗(yàn)證 @Email(message = "郵箱格式錯誤") private String email; @Size(min = 20, max = 30, message = "字符串長度要求20到30之間。") private String size; public Long getId() { return id; } public void setId(Long id) { this.id = id; } public Date getDate() { return date; } public void setDate(Date date) { this.date = date; } public Double getDoubleValue() { return doubleValue; } public void setDoubleValue(Double doubleValue) { this.doubleValue = doubleValue; } public Integer getInteger() { return integer; } public void setInteger(Integer integer) { this.integer = integer; } public Long getRange() { return range; } public void setRange(Long range) { this.range = range; } public String getEmail() { return email; } public void setEmail(String email) { this.email = email; } public String getSize() { return size; } public void setSize(String size) { this.size = size; } /**** setter and getter ****/ }
此時controller應(yīng)該要加上@Valid ,否則不會驗(yàn)證!
/*** * 解析驗(yàn)證參數(shù)錯誤 * @param vp —— 需要驗(yàn)證的POJO,使用注解@Valid 表示驗(yàn)證 * @param errors 錯誤信息,它由Spring MVC通過驗(yàn)證POJO后自動填充 * @return 錯誤信息Map */ @RequestMapping(value = "/valid/validate") @ResponseBody public Map<String, Object> validate( @Valid @RequestBody ValidatorPojo vp, Errors errors) { Map<String, Object> errMap = new HashMap<>(); // 獲取錯誤列表 List<ObjectError> oes = errors.getAllErrors(); for (ObjectError oe : oes) { String key = null; String msg = null; // 字段錯誤 if (oe instanceof FieldError) { FieldError fe = (FieldError) oe; key = fe.getField();// 獲取錯誤驗(yàn)證字段名 } else { // 非字段錯誤 key = oe.getObjectName();// 獲取驗(yàn)證對象名稱 } // 錯誤信息 msg = oe.getDefaultMessage(); errMap.put(key, msg); } return errMap; }
以上就是關(guān)于如何使用spring注解驗(yàn)證@NotNull的內(nèi)容,如果你們有學(xué)習(xí)到知識或者技能,可以把它分享出去讓更多的人看到。
本文名稱:如何使用spring注解驗(yàn)證@NotNull
分享鏈接:http://muchs.cn/article42/jcpdec.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供建站公司、商城網(wǎng)站、企業(yè)建站、App開發(fā)、軟件開發(fā)、網(wǎng)站建設(shè)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)