Un: Préface
Lors de la construction d'un projet springboot, en utilisant l'interface Restful, lorsque l'interface d'appel frontale ou d'autres appels de projet, nous ne pouvons pas nous fier uniquement à l'appelant pour contrôler l'exactitude des paramètres, et nous devons juger nous-mêmes certaines valeurs non vides.
Deux: les solutions traditionnelles
Autrement dit, nous effectuons des opérations nulles sur les paramètres un par un dans le code.
Modèle:
/**
* @author: liman
* @Date: 2020/7/20 16:27
* @Description:
*/
public class User{
private Long userID;
private Long addressID;
private String userName;
}
Manette:
@PostMapping("/createUser")
public String createUser(@RequestBody User dto) {
if(dto.getUserID==null)
return "userID不能为空";
if(dto.getAddressID==null)
return "addressID不能为空";
if(dto.getUserName==null)
return "comment不能为空";
return "sucess";
}
Cette approche peut répondre à nos exigences, mais s'il y a trop de champs de modèle, il y aura beaucoup de jugements, ce qui n'est pas si pratique à maintenir. Deuxièmement, cela augmente la charge de la couche contrôleur. Puisque nous sommes à l'ère du printemps 4, nous devons nous adapter à l'utilisation des annotations Voici le changement de rapport après l'utilisation des annotations.
Développement annoté:
Modèle:
public class User{
@NotNull(message = "用户ID不能为空")
private Long userID;
@Valid // 重点在这里,一定要加上@Valid,Demo2中的校验才会生效,否则不会生效
@NotNull(message = "收货人地址id不能为空")
private Long addressID;
@NotBlank(message = "备注不为空")
private String userName;
}
Contrôleur: ajoutez l'annotation @Valid aux paramètres à vérifier dans la méthode de la couche contrôleur
@PostMapping("/createUser")
public String createOrders(@RequestBody @Valid User dto, BindingResult results) { // 重点在这里,需要加上@Valid才会去校验
if (results.hasErrors())
return results.getFieldError().getDefaultMessage();
return "success";
}
De cette manière, il suffit d'ajouter une vérification non vide et les invites correspondantes dans le champ de modèle.
Trois: les annotations couramment utilisées @Valid sont les suivantes:
@Null 限制只能为null
@NotNull 限制必须不为null
@AssertFalse 限制必须为false
@AssertTrue 限制必须为true
@DecimalMax(value) 限制必须为一个不大于指定值的数字
@DecimalMin(value) 限制必须为一个不小于指定值的数字
@Digits(integer,fraction) 限制必须为一个小数,且整数部分的位数不能超过integer,小数部分的位数不能超过fraction
@Future 限制必须是一个将来的日期
@Max(value) 限制必须为一个不大于指定值的数字
@Min(value) 限制必须为一个不小于指定值的数字
@Past 限制必须是一个过去的日期
@Pattern(value) 限制必须符合指定的正则表达式
@Size(max,min) 限制字符长度必须在min到max之间
@Past 验证注解的元素值(日期类型)比当前时间早
@NotEmpty 验证注解的元素值不为null且不为空(字符串长度不为0、集合大小不为0)
@NotBlank 验证注解的元素值不为空(不为null、去除首位空格后长度为0),不同于@NotEmpty,@NotBlank只应用于字符串且在比较时会去除字符串的空格
@Email 验证注解的元素值是Email,也可以通过正则表达式和flag指定自定义的email格式
需要注意每个注解对应的数据类型
Par exemple:
//@NotNull:主要用在基本数据类型上(Int,Integer,Double,Date)
@NotNull(message = “年龄不能为空”)
private Integer age;
//@NotBlank:主要用在String字符串上面(String)
@NotBlank(message = “名字不能为空”)
private String name;
//@NotEmpty; 加了@NotEmpty注解的String类 ,Collection集合,Map ,数组,这些是不能为null或者长度为0的;(String ,Collection,Map的isEmpty()方法)