springmvc中如何驗證框架
阿新 • • 發佈:2019-02-05
springmvc中如何使用驗證框架
客戶端驗證(js) + 伺服器端驗證(java)
客戶端驗證能夠提供更好的體驗,但是不夠安全。永遠不要將驗證寄託於客戶端驗證。伺服器端驗證才永遠安全
1.springmvc 和 hibernate-validation驗證框架的整合
首先要根據spring的版本匯入不同版本的hibernate-validation的jar包
springmvc 3.x
hibernate-validator-4.1.0.Final.jar
validation-api-1.0.0.GA.jar
jboss-logging-3.1.0.GA.jar
springmvc 4.x
classmate-1.3.1.jar
hibernate-validator-5.3.1.Final.jar
jboss-logging-3.3.0.Final.jar
validation-api-1.1.0.Final.jar
2.hibernate-validation驗證框架所提供的關於驗證的註解
* @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(regex=,flag=) 被註釋的元素必須符合指定的正則表示式
* Hibernate Validator 附加的 constraint
* @NotBlank(message =) 驗證字串非null,且長度必須大於0
* @Email 被註釋的元素必須是電子郵箱地址
* @Length(min=,max=) 被註釋的字串的大小必須在指定的範圍內
* @NotEmpty 被註釋的字串的必須非空
* @Range(min=,max=,message=) 被註釋的元素必須在合適的範圍內
* @URL(protocol=,host,port)//檢查是否是一個有效的URL,如果提供了protocol,host等,則該URL還需滿足提供的條件
3.驗證的使用步驟
1>.匯入驗證相關的jar包
2>.在實體類的相應屬性上添加註解
@NotBlank(message="商品名稱不能為空")
private String goodsName;
@NotNull(message="商品價格不能為空")
@DecimalMin(value="0", message="價格不能小於0")
private Double price;
@Min(value=0, message="庫存數量不能小於0")
private Integer storage;
3>.在springmvc的控制器方法上,添加註解和引數
@RequestMapping(value="/add", method=RequestMethod.POST)
public String add(@Validated @ModelAttribute("goods") Goods goods, BindingResult validResult){
if(validResult.hasFieldErrors()==true){
return "goods/add";
}
goods.setGoodsId(generateGoodsId());
goodsList.add(goods);
return "redirect:list";
}
注意:BindingResult引數必須緊跟被驗證的引數
客戶端驗證(js) + 伺服器端驗證(java)
客戶端驗證能夠提供更好的體驗,但是不夠安全。永遠不要將驗證寄託於客戶端驗證。伺服器端驗證才永遠安全
1.springmvc 和 hibernate-validation驗證框架的整合
首先要根據spring的版本匯入不同版本的hibernate-validation的jar包
springmvc 3.x
hibernate-validator-4.1.0.Final.jar
validation-api-1.0.0.GA.jar
jboss-logging-3.1.0.GA.jar
springmvc 4.x
classmate-1.3.1.jar
hibernate-validator-5.3.1.Final.jar
jboss-logging-3.3.0.Final.jar
validation-api-1.1.0.Final.jar
2.hibernate-validation驗證框架所提供的關於驗證的註解
* @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(regex=,flag=) 被註釋的元素必須符合指定的正則表示式
* Hibernate Validator 附加的 constraint
* @NotBlank(message =) 驗證字串非null,且長度必須大於0
* @Email 被註釋的元素必須是電子郵箱地址
* @Length(min=,max=) 被註釋的字串的大小必須在指定的範圍內
* @NotEmpty 被註釋的字串的必須非空
* @Range(min=,max=,message=) 被註釋的元素必須在合適的範圍內
* @URL(protocol=,host,port)//檢查是否是一個有效的URL,如果提供了protocol,host等,則該URL還需滿足提供的條件
3.驗證的使用步驟
1>.匯入驗證相關的jar包
2>.在實體類的相應屬性上添加註解
@NotBlank(message="商品名稱不能為空")
private String goodsName;
@NotNull(message="商品價格不能為空")
@DecimalMin(value="0", message="價格不能小於0")
private Double price;
@Min(value=0, message="庫存數量不能小於0")
private Integer storage;
3>.在springmvc的控制器方法上,添加註解和引數
@RequestMapping(value="/add", method=RequestMethod.POST)
public String add(@Validated @ModelAttribute("goods") Goods goods, BindingResult validResult){
if(validResult.hasFieldErrors()==true){
return "goods/add";
}
goods.setGoodsId(generateGoodsId());
goodsList.add(goods);
return "redirect:list";
}
注意:BindingResult引數必須緊跟被驗證的引數