国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - java自定義注解驗證手機格式的實現示例

java自定義注解驗證手機格式的實現示例

2021-08-20 11:06菜-菜-菜 Java教程

這篇文章主要介紹了java自定義注解驗證手機格式的實現示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

1、@Valid與@Validated的區別

1.1 基本區別

@Valid:Hibernate validation校驗機制

@Validated:Spring Validator校驗機制,這個也是最常用的

@Validation只是對@Valid進行了二次封裝,在使用上并沒有太大區別,但在分組、注解位置、嵌套驗證等功能上有所不同

1.2 作用范圍

@Validated:用在類型、方法和方法參數上。但不能用于成員屬性(field)
@Valid:可以用在方法、構造函數、方法參數和成員屬性(field)上

1.3 分組校驗

@Validated:提供分組功能,可以在參數驗證時,根據不同的分組采用不同的驗證機制,注解中必須提供groups屬性,該屬性就是做分組的必要參數
@Valid:沒有分組功能

2、未使用分組校驗的示例

注解:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
/**
 * 手機號驗證正則
 */
@Target({ElementType.FIELD,ElementType.METHOD})
@Retention(RetentionPolicy.RUNTIME)
@Documented
@Constraint(validatedBy = {PhoneValidator.class})// 指定約束處理器,也就是手機號格式驗證是哪個類來做校驗
public @interface Phone {
 
  String pattern() default "^(?:(?:\\+|00)86)?1\\d{10}$";
 
  String message() default "手機號格式非法";
 
  Class<?>[] groups() default { }; // groups用來指定分組,可以讓校驗采取不同的機制,當前默認未指定任何分組機制,默認每次都要進行校驗
 
  Class<? extends Payload>[] payload() default { };
  
  // 默認分組
  interface Default{
 
  }
 
  // 分組A
  interface A{
 
  }
}

格式校驗處理器:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
/**
 * 校驗處理器:做手機號碼格式驗證的核心類
 */
public class PhoneValidator implements ConstraintValidator<Phone, String> {
 
  // 注解對象
  private Phone phone;
 
  // 初始化【Phone】對象
  @Override
  public void initialize(Phone constraintAnnotation) {
    phone = constraintAnnotation;
  }
 
  @Override
  public boolean isValid(String value, ConstraintValidatorContext context) {
    // 獲取【Phone】對象的手機格式驗證表達式
    String pattern = phone.pattern();
    Pattern compile = Pattern.compile(pattern);
    Matcher matcher = compile.matcher(value);
    return matcher.matches();
  }

作用類:

?
1
2
3
4
5
6
7
8
@Data
@EqualsAndHashCode(callSuper = false)
@Accessors(chain = true)
public class Person implements Serializable {
  
  @Phone
  private String phone;
}

注意:只有在spring或者springboot項目中才能使用,直接調用方法不會有任何效果,使用注解進行對象的屬性格式校驗時,必須配合@Validated一起使用(不一起使用,格式校驗注解將會無效),正確操作如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
@RestController
@RequestMapping("/admin/")
public class PersonController {
 
  @Autowired
  private PersonService personService;
 
  @PostMapping("/query")
  public Person query(@RequestBody @Validated Person params) {
    return JsonResult.success(personService.queryByPhone(params));
  }
}

以上示例未使用分組功能,因此每次都會校驗。

3、分組校驗的示例

使用分組校驗示示例時,先要看看@Validated注解,因為分組校驗就是配合該注解一起使用的,通過閱讀注釋就能理解到value屬性就是用來指定分組的:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
@Target({ElementType.TYPE, ElementType.METHOD, ElementType.PARAMETER})
@Retention(RetentionPolicy.RUNTIME)
@Documented
public @interface Validated {
 
 /**
 * Specify one or more validation groups to apply to the validation step
 * kicked off by this annotation.
 * <p>JSR-303 defines validation groups as custom annotations which an application declares
 * for the sole purpose of using them as type-safe group arguments, as implemented in
 * {@link org.springframework.validation.beanvalidation.SpringValidatorAdapter}.
 * <p>Other {@link org.springframework.validation.SmartValidator} implementations may
 * support class arguments in other ways as well.
 */
 Class<?>[] value() default {};
 
}

因此我們需要改動的位置有兩處:

  • 首先是注解的作用類,注解上指定groups屬性
  • 其次是controller中的請求的形參:在請求中形參的@Validated指定value值,也就是指定校驗生效的分組,如果請求中的分組類型【@Validated的value值】和作用類中注解所指定的分組【@Phone中的groups屬性的值】一致時,才會進行校驗,否則不會執行校驗

作用類:

?
1
2
3
4
5
6
7
8
9
10
@Data
@EqualsAndHashCode(callSuper = false)
@Accessors(chain = true)
public class Person implements Serializable {
  
  // 指定groups屬性
  @Phone(groups = {Phone.A.class})
  private String phone;
 
}

controller層:

?
1
2
3
4
5
6
7
8
9
10
11
12
@RestController
@RequestMapping("/admin/")
public class PersonController {
 
  @Autowired
  private PersonService personService;
 
  @PostMapping("/query")
  public Person query(@RequestBody @Validated(Phone.A.class) Person params) {
    return JsonResult.success(personService.queryByPhone(params));
  }
}

此時請求中的校驗分組Phone.A.class和作用類中的校驗分組Phone.A.class一致,所以校驗會被執行

到此這篇關于java自定義注解驗證手機格式的實現示例的文章就介紹到這了,更多相關java自定義注解驗證手機格式內容請搜索服務器之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持服務器之家!

原文鏈接:https://blog.csdn.net/qq_44309181/article/details/114300078

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 欧美日韩国产精品一区二区 | 四虎影院在线免费播放 | 亚洲一区二区精品 | 亚洲欧美激情精品一区二区 | 人成网址| 国产精品久久电影观看 | 在线观看三级网站 | 免费又黄又爽又色的视频 | 亚洲精品系列 | 丁香五月亚洲综合在线 | 中文字幕在线观看一区 | 成人欧美 | 九九亚洲精品 | 日韩国产 | 日韩精品www | 黄网站色 | 久草视频网 | 国产毛片欧美毛片久久久 | 亚洲精品国精品久久99热 | 久久伊人久久 | 成人av电影在线观看 | 亚洲欧美日韩精品久久亚洲区 | 九九九久久国产免费 | 欧美中文在线 | 免费在线观看黄色 | 国产又色又爽又黄又免费 | 欧美精品成人一区二区三区四区 | 一区二区三区高清 | 精品久久中文字幕 | 久久综合一区 | 久久亚洲国产精品 | 在线一级片 | 91最新网站| 亚洲成人av | 久久精品国产91精品亚洲高清 | 91午夜伦伦电影理论片 | 久久久久久久久久久美女 | 欧美成人h版在线观看 | 一本大的之伊人 | 欧美日韩在线不卡 | 亚洲精品视频免费观看 |