java自定義驗(yàn)證器的實(shí)現(xiàn)示例
前言
在對外暴露接口中,我們通常會對入?yún)⑦M(jìn)行驗(yàn)證,比如一些字符串非空判斷、數(shù)字最小值最大值這些基礎(chǔ)的判斷在java驗(yàn)證規(guī)范中已經(jīng)提供了,然而這些只是常規(guī)的驗(yàn)證,我們可以通過自定義注解以及驗(yàn)證器來進(jìn)行我們自己業(yè)務(wù)上的一些驗(yàn)證,這樣可以避免在業(yè)務(wù)邏輯中添加過多的驗(yàn)證,降低代碼的可讀性。
使用
1、依賴引入
僅需引入驗(yàn)證包即可,當(dāng)然,如果使用的springboot,可以直接管理依賴,不用指定版本
<dependency>
<groupId>javax.validation</groupId>
<artifactId>validation-api</artifactId>
</dependency>
2、自定義注解
這里添加一個(gè)銀行卡驗(yàn)證的注解,其實(shí)核心注解就是@Constraint,這個(gè)注解要求我們的注解中必須有message()groups()以及payload()這三個(gè)方法
import javax.validation.Constraint;
import javax.validation.Payload;
import java.lang.annotation.*;
/**
* 銀行卡號校驗(yàn)注解
*/
@Documented
@Retention(RetentionPolicy.RUNTIME)
// 這里指定驗(yàn)證器
@Constraint(validatedBy = {BankCardValidator.class})
@Target({ElementType.FIELD,ElementType.ANNOTATION_TYPE,ElementType.PARAMETER})
public @interface BankCardValidity {
/**
* 提示信息
* @return String
*/
String message() default "";
/**
* 是否驗(yàn)證
* @return boolean
*/
boolean required() default true;
/**
* groups
* @return []
*/
Class<?>[] groups() default {};
/**
* payload
* @return []
*/
Class<? extends Payload>[] payload() default {};
}
3、編寫驗(yàn)證器
驗(yàn)證器的核心是實(shí)現(xiàn)ConstraintValidator這個(gè)類,第一個(gè)參數(shù)是指定注解,第二個(gè)則是指定的入?yún)?/p>
import javax.validation.ConstraintValidator;
import javax.validation.ConstraintValidatorContext;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
/**
* 銀行卡號校驗(yàn)器
*/
public class BankCardValidator implements ConstraintValidator<BankCardValidity,String> {
/**
* 是否強(qiáng)制驗(yàn)證
*/
private boolean required = false;
/**
* 銀行卡號正則校驗(yàn),這里就是一個(gè)正則驗(yàn)證
*/
private static Pattern patternForBankCardNo = Pattern.compile("^([1-9]{1})(\\d{15}|\\d{18})$");
/**
* 這里就是驗(yàn)證邏輯,返回true驗(yàn)證通過,返回false驗(yàn)證不通過
*/
@Override
public boolean isValid(String bankCardNo, ConstraintValidatorContext context) {
if (required) {
return isBankCardNo(bankCardNo);
} else {
if (StrUtil.isBlank(bankCardNo)) {
return false;
}
return isBankCardNo(bankCardNo);
}
}
@Override
public void initialize(BankCardValidity validity) {
required = validity.required();
}
/**
* 驗(yàn)證是否為銀行卡號
* @param bankCardNo 輸入內(nèi)容
* @return boolean
*/
private static boolean isBankCardNo(String bankCardNo) {
// 使用的hutool工具包,也可以使用其它工具包
if (StrUtil.isBlank(bankCardNo)) {
return false;
}
Matcher matcherForBankCardNo = patternForBankCardNo.matcher(bankCardNo);
return matcherForBankCardNo.matches() ;
}
}
至此編碼就完成了,我們可以在注解中添加新的方法,在initialize()方法中使用,或者取值等操作,這都是根據(jù)業(yè)務(wù)場景來進(jìn)行的。
當(dāng)然,在入?yún)⑿z中,我們肯定也需要把@Valid等注解加上,驗(yàn)證器才會去驗(yàn)證。
到此這篇關(guān)于java自定義驗(yàn)證器的實(shí)現(xiàn)示例的文章就介紹到這了,更多相關(guān)java自定義驗(yàn)證器內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
java String類常量池分析及"equals"和"==”區(qū)別詳細(xì)介紹
這篇文章主要介紹了java String類常量池分析及"equals"和"==”區(qū)別詳細(xì)介紹的相關(guān)資料,需要的朋友可以參考下2016-12-12
Java利用ElasticSearch實(shí)現(xiàn)自動補(bǔ)全功能
這篇文章主要為大家詳細(xì)介紹了Java如何利用ElasticSearch實(shí)現(xiàn)跟谷歌和百度類似的下拉補(bǔ)全提示功能,文中的示例代碼講解詳細(xì),需要的可以參考一下2023-08-08
Java實(shí)現(xiàn)度分秒坐標(biāo)轉(zhuǎn)十進(jìn)制度
隨著技術(shù)的發(fā)展,十進(jìn)制度因其精確性和便捷性在現(xiàn)代應(yīng)用中越來越受到青睞,下面我們就來看看如何使用Java實(shí)現(xiàn)度分秒坐標(biāo)轉(zhuǎn)十進(jìn)制度吧2024-12-12
springboot使用Thymeleaf報(bào)錯(cuò)常見的幾種解決方案
這篇文章主要介紹了springboot使用Thymeleaf報(bào)錯(cuò)常見的幾種解決方案,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-11-11
SpringBoot3和mybatis-plus整合出現(xiàn)的問題解決辦法
SpringBoot和MybatisPlus的整合可以讓我們更加方便地進(jìn)行數(shù)據(jù)庫操作,這篇文章主要給大家介紹了關(guān)于SpringBoot3和mybatisplus整合出現(xiàn)的一些問題的相關(guān)資料,需要的朋友可以參考下2024-01-01
通過IEAD+Maven快速搭建SSM項(xiàng)目的過程(Spring + Spring MVC + Mybatis)
這篇文章主要介紹了通過IEAD+Maven快速搭建SSM項(xiàng)目的過程(Spring + Spring MVC + Mybatis),本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-01-01

