SpringBoot基础教程2-1-6 日志规范-使用AOP统一处理Web日志

本文介绍了如何在SpringBoot中通过AOP实现Web日志的统一处理,避免验证逻辑与业务逻辑耦合。内容包括不合理验证方式的问题、优雅的数据验证方式的实现步骤,如添加依赖、创建实体类以及使用特定注解进行数据有效性校验。最后,文章还展示了测试结果和工程目录。
摘要由CSDN通过智能技术生成

1. 概述

数据验证是企业应用开发中必备可少的环节,通常如果使用if-else在业务代码中写死验证逻辑,会导致验证逻辑与业务逻辑耦合。

2. 不合理的验证方式

public class BadDemo {

    public void bad(String str){
        if(null == str){
            throw new NullPointerException("str 不能为空");
        }

        // todo 业务逻辑
    }
}

上述代码,如果需要修改验证,str不为空且长度大于8,只能强行修改代码。

3. 优雅的数据验证方式

3.1. 添加pom.xml依赖

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-web</artifactId>
</dependency>

3.2 创建实体类

@Data
public class User {

    @NotNull(message = "名字不能为空")
    @Length(min = 4, max = 10, message = "name 长度必须在 {min} - {max} 之间")
    private String name;

    @NotNull(message = "年龄不能为空")
    @Min(value = 18, message = "年龄不能小于18岁")
    private Integer age;
}

JSR-303 注解解释

注解说明
@NotNull限制必须不为null
@NotEmpty验证注解的元素值不为 null 且不为空(字符串长度不为0、集合大小不为0)
@NotBlank验证注解的元素值不为空(不为null、去除首位空格后长度为0),不同于@NotEmpty,@NotBlank只应用于字符串且在比较时会去除字符串的空格
@Pattern(value)限制必须符合指定的正则表达式
@Size(max,min)限制字符长度必须在 min 到 max 之间(也可以用在集合上)
@Email验证注解的元素值是Email,也可以通过正则表达式和flag指定自定义的email格式
@Max(value)限制必须为一个不大于指定值的数字
@Min(value)限制必须为一个不小于指定值的数字
@DecimalMax(value)限制必须为一个不大于指定值的数字
@DecimalMin(value)限制必须为一个不小于指定值的数字
@Null限制只能为null(很少用)
@AssertFalse限制必须为false (很少用)
@AssertTrue限制必须为true (很少用)
@Past限制必须是一个过去的日期
@Future限制必须是一个将来的日期
@Digits(integer,fraction)限制必须为一个小数,且整数部分的位数不能超过 integer,小数部分的位数不能超过 fraction (很少用)

- 这里只列举了 javax.validation 包下的注解,同理在 spring-boot-starter-web 包中也存在hibernate-validator 验证包,里面包含了一些 javax.validation 没有的注解,有兴趣的可以看看

3.3 Controller

@Validated
@RestController
public class UserController {

    @PostMapping("/user")
    public R addUser(@Validated @RequestBody User user, BindingResult br){

        if(br.hasErrors()){
            return R.isFail().msg(br.getFieldError().getDefaultMessage());
        } else {

            return R.isOk().data(user);
        }
    }

    @GetMapping("/user")
    public R test2(
            @NotBlank(message = "name 不能为空")
            @Length(min = 2, max = 10, message = "name 长度必须在 {min} - {max} 之间")
                    String name ) {

        return R.isOk().data(name);
    }
}

注解解释
- @Validated: 开启数据有效性校验,添加在类上即为验证方法,添加在方法参数中即为验证参数对象。(添加在方法上无效)
- @NotBlank: 被注释的字符串不允许为空
- @Length: 被注释的字符串的大小必须在指定的范围内
- @NotNull: 被注释的字段不允许为空
- @DecimalMin: 被注释的字段必须大于或等于指定的数值

4. 测试结果

5. 工程目录

6. 结束语

说点什么呢,有任何建议,欢迎留言探讨,本文源码


欢迎关注博主公众号,第一时间推送最新文章

欢迎关注博主公众号

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值