自定義注解進行restful請求參數的校驗
在使用springmvc開發的時候,我們通常會在controller中的方法參數實體類中加上@NotNull()等類似注解,然后在方法參數上加上
@Vilad 注解,這樣在有請求的時候,就會自動按照我們的注解進行參數是否合法,避免了我們手工的校驗。
但是,自帶的校驗注解有的時候并不能滿足我們的業務驗證需求,因此,我們就有必要進行自定義校驗注解,以業務為需求定制我們
自己的校驗注解。
下面我們來看一個例子:
1、首先我們使用@interface定義一個注解
@Target( { METHOD, FIELD, ANNOTATION_TYPE }) @Retention(RUNTIME) @Constraint(validatedBy = ByteLengthValidator.class)// 使用@Constraint指定注解校驗實現類,這是一個限制型注解,只能使用指定的實現類 @Documented public @interface ByteLength { int min() default 0; int max() default 2147483647; String charsetName() default "GBK"; String message() default "的長度只能在{min}和{max}之間"; Class<?>[] groups() default {}; Class<? extends Payload>[] payload() default {}; }
2、實現注解實現類(和@interface定義的注解在同一個包下)
注解實現類需要實現ConstraintValidator 接口
public class ByteLengthValidator implements ConstraintValidator<ByteLength, String>{ // 實現ConstraintValidator int min; int max; String charsetName; @Override public void initialize(ByteLength constraintAnnotation) { this.min = constraintAnnotation.min(); this.max = constraintAnnotation.max(); this.charsetName = constraintAnnotation.charsetName(); } @Override public boolean isValid(String value, ConstraintValidatorContext context) { // 實現校驗規則 if (null == value) { return min <= 0; } try { int length = value.getBytes(charsetName).length; return length >= min && length <= max; } catch (UnsupportedEncodingException e) { e.printStackTrace(); return false; } } }
3、在需要校驗的對象的字段上加上@ByteLength注解
然后在接口方法的該對象參數上加上@Vilad 注解,在接收的請求的時候,就會使用
我們自定義的@ByteLength 進行校驗該字段。
springboot小技巧:restful接口參數校驗,自定義校驗規則
restful風格接口參數校驗
在接收參數的實體類的屬性上添加默認的注解或者自定義注解
自定義參數校驗注解方法
1>定義自定義注解
2>定義參數校驗邏輯的處理類
以上為個人經驗,希望能給大家一個參考,也希望大家多多支持服務器之家.
原文鏈接:https://blog.csdn.net/qq_30698633/article/details/75390197