SpringBoot自定义业务错误信息

  借助Java提供的参数校验器,可以很方便的进行业务参数校验。
引入下面连个jpom文件
<!--StringUtls工具类依赖-->
        <dependency>
           <groupId>org.apache.commons</groupId>
           <artifactId>commons-lang3</artifactId>
            <version>3.7</version>
        </dependency>
        <!--hibernate validator验证器-->
        <dependency>
           <groupId>org.hibernate.validator</groupId>
            <artifactId>hibernate-validator</artifactId>
           <version>6.0.13.Final</version>
</dependency>
       构建 validatorResult.java 和 validatorImpl.java来进行参数检验。具体代码如下
validatorResult.java提供对校验结果进行判断
@Data
public classvalidatorResult {
 
    private Boolean hasError=false;
    private Map<String,String> errorMap =new HashMap<>();
 
    public String getErrorMsg(){
 
        returnStringUtils.join(errorMap.values().toArray(),",");
    }

 

validatorImpl.java实现具体的参数校验规则
@Component
public classvalidatorImpl implements InitializingBean {
    private Validator validator;
 
    @Override
    public void afterPropertiesSet() throwsException {
        this.validator =Validation.buildDefaultValidatorFactory().getValidator();
    }
 
    public validatorResult validators(Objectbeans) {
        validatorResult validatorResult = newvalidatorResult();
       Set<ConstraintViolation<Object>> violationSet =validator.validate(beans);
        if (violationSet.size() > 0) {
            validatorResult.setHasError(true);
           violationSet.forEach(constraintViolation -> {
                String errMsg =constraintViolation.getMessage();
                String propertiesName =constraintViolation.getPropertyPath().toString();
                validatorResult.getErrorMap().put(propertiesName,errMsg);
            });
        }
        return validatorResult;
    }

 

      最后在VOmodel对象的属相上使用Java提供的校验规则进行使用

 

@Data
public classuserVO implements Serializable {
    private Long id;
    @NotBlank(message = "姓名不能为空") //即参数不能为空并且参数不能为null
    private String name;
    @NotNull(message="年龄不能为空")
    @Max(value = 100,message = "年龄不能大于100")
    @Min(value = 0,message = "年龄不能小于0")
    private Integer age;

 

      利用postman进行测试结果为
{
    "status": "fail",
    "data": {
        "errCode": 10001,
        "errMsg": "年龄不能小于0"
    }
}
{
    "status": "fail",
    "data": {
        "errCode": 10001,
        "errMsg": "年龄不能小于0"
    }
}
     业务层代码

@RestController
public classuserController extends BaseController {
    @Autowired
    private validatorImpl validator;
 
    @GetMapping(value = "/hello")
    public CommonReturn sayHello(userVO vo)throws BusinessException {
 
        validatorResult result =validator.validators(vo);
        if (result.getHasError()){
         throw newBusinessException(EmBusinessError.PARAMETER_VALIDATION_ERROR,result.getErrorMsg());
        }
        return CommonReturn.create(vo);
    }
}
到此利用Java进行校验完成
Spring Boot 自定义注解通常用于提供额外的功能或者业务规则,它们允许开发者在代码中添加特定于应用的元数据。自定义注解处理器(Annotation Processor)是一种特殊类型的 Java 编译器插件,它会在编译期间扫描并处理包含自定义注解的源代码。 创建 Spring Boot 的自定义注解,首先你需要定义注解的结构,比如@MyCustomAnnotation,然后可以在其中设置属性值。例如: ```java @Retention(RetentionPolicy.RUNTIME) @Target(ElementType.TYPE) public @interface MyCustomAnnotation { String value() default ""; } ``` 接下来,为了使注解处理器生效,需要创建一个实现了`javax.annotation.processing.Processor`接口的类,并在其中实现`process()`方法,这个方法会接收包含自定义注解的源文件列表作为输入: ```java @Component public class MyCustomAnnotationProcessor implements javax.annotation.processing.Processor { // ... 实现 process() 方法 } ``` 为了让IDE(如IntelliJ IDEA或Eclipse)能够识别并启用你的注解处理器,你需要在项目的`META-INF/services/javax.annotation.processing.Processor`文件中列出你的处理器全限定名。 当你在代码中使用自定义注解,编译时处理器会被自动调用,它可以生成字节码、修改元数据等。举个例子,处理器可能会检查标注了`@MyCustomAnnotation`的类是否满足某些条件,如果不符合则抛出错误或者生成警告。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值