注解

用于类上的注解

@Accessors

一般用chain=true,当该值为true时,调用setter方法时会返回当前的对象,方便采取链式编程的方法进行代码编写

列如:CatSetName(123).setAge(20).setId();

fluent属性为true时,对应的getter方法前没有get,setter方法前没有set

prefix属性可以忽略前缀

lombok注解

@Setter

@getter

@Tostring

@EqualsAndHushcode

excude可以排除一些属性,of可以指定某些属性

默认即callSuper =false时仅使用该类中定义的属性,当为true时可以调用父类中的属性

@RequiredArgsContructor

​ 包含特定参数的构造器,特定参数指的是final修饰的关键字

@Data

​ 包含以上五个注解

@NoArgsContructor

@AllArgsContructor

MybatisPlus中的注解

@TableName("tb_")

@TableId (value=" ",id排序)

@Tablefield

select=false//查询不返回该字段的值

value="" //通过进行字段不一致的映射

exist = false //设置该字段在表中不存在

fill = FieldFill.INSERT //创建记录的时候使用

fill = FieldFill.INSERT_UPDATE //创建和更新记录时操作的时候都会使用

fill = FieldFill.UPDATE //更新记录的的时候使用

@TableLogic

value="原值",devalue="删除后的值" //自己随意设置

@Version

校验注解:判断某个类中的属性值是否为空或者null等等;(可以省去写if判断从前端拿来的参数是否为空)

实体字段校验 @NotNull、@NotEmpty、@NotBlank

@NotNull(Messaage = "xxx不能为空")

不能为 null,但可以为 empty,一般用在 Integer 类型的基本数据类型的非空校验上,而且被其标注的字段可以使用 @size、@Max、@Min 对字段数值进行大小的控制

@NotEmpty

不能为 null,且长度必须大于 0,一般用在集合类上或者数组上

@NotBlank

只能作用在接收的 String 类型上,注意是只能,不能为 null,而且调用 trim() 后,长度必须大于 0即:必须有实际字符

注意在使用 @NotBlank 等注解时,一定要和 @valid 一起使用,否则 @NotBlank 不起作用。
一个 BigDecimal 的字段使用字段校验标签应该为 @NotNull。
在使用 @Length 一般用在 String 类型上可对字段数值进行最大长度限制的控制。
在使用 @Range 一般用在 Integer 类型上可对字段数值进行大小范围的控制。

1.String name = null;

@NotNull: false
@NotEmpty:false 
@NotBlank:false 



2.String name = "";

@NotNull:true
@NotEmpty: false
@NotBlank: false



3.String name = " ";

@NotNull: true
@NotEmpty: true
@NotBlank: false



4.String name = "Hello World!";

@NotNull: true
@NotEmpty:true
@NotBlank:true

常用的校验注解

依赖性项:

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-validation</artifactId>
    <version>3.0.2</version>
</dependency>

在这个包下javax.validation.constraints.xxx
注解 说明
@Null 被注释的元素必须为null
@NotNull 被注释的元素不能为null
@AssertTrue 被注释的元素必须为true
@AssertFalse 被注释的元素必须为false
@Min(value) 被注释的元素必须是一个数字,其值必须大于等于指定的最小值
@Max(value) 被注释的元素必须是一个数字,其值必须小于等于指定的最大值
@DecimalMin(value) 被注释的元素必须是一个数字,其值必须大于等于指定的最小值
@DecimalMax(value) 被注释的元素必须是一个数字,其值必须小于等于指定的最大值
@Size(max,min) 被注释的元素的大小必须在指定的范围内。
@Digits(integer,fraction) 被注释的元素必须是一个数字,其值必须在可接受的范围内
@Past 被注释的元素必须是一个过去的日期
@Future 被注释的元素必须是一个将来的日期
@Pattern(value) 被注释的元素必须符合指定的正则表达式。
@Email 被注释的元素必须是电子邮件地址
@Length 被注释的字符串的大小必须在指定的范围内
@NotEmpty 被注释的字符串必须非空
@Range 被注释的元素必须在合适的范围内

附 @JsonFormat //包:com.fasterxml.jackson.annotation.JsonFormat;
有时使用 @JsonFormat 注解时,查到的时间可能会比数据库中的时间少八个小时,这是由于时区差引起的,JsonFormat 默认的时区是 Greenwich Time, 默认的是格林威治时间,而我们是在东八区上,所以时间会比实际我们想得到的时间少八个小时。需要在后面加上一个时区,如下示例:
1
@JsonFormat(pattern=“yyyy-MM-dd”,timezone=“GMT+8”)
private Date date;

@JsonFormat(pattern=“yyyy-MM-dd”,timezone=“GMT+8”)
private Date date;

配置单独的异常处理返回特定的message的内容返回给前端:

@ExceptionHandler(BindException.class)
@ResponseBody
public Result error(BindException e){
    e.printStackTrace();
    String defaultMessage = e.getBindingResult().getAllErrors().get(0).getDefaultMessage();
    return Result.fail(defaultMessage);
}

异常类注解

//assignable,指定一个或多个controller类被ControllerAdvice管理

//basePackages,指定一个或多个包,这些包下的所有controller都被ControllerAdvice进行管理

//包含RestConteroller注解的类都被ControllerAdvice进行管理

@RestControllerAdvice(annotations = {RestController.class})

@ExceptionHandler(xxxxException.Class) //进行异常处理,示例

 @ExceptionHandler(SQLIntegrityConstraintViolationException.class)
    public R<String> exceptionHandler(SQLIntegrityConstraintViolationException ex) {
        //测试但不具体
//        log.info(ex.getMessage());
//        return R.error("名字重复,请重输");


        //具体解决

        if (ex.getMessage().contains("Duplicate entry")) {
            String[] arrs = ex.getMessage().split(" ");
            String msg = arrs[2] + "已被注册,请重新输入";
            return R.error(msg);
        }
        return R.error("位置错误");


    }

自定义异常示例

(1)创建自定义异常类继承RunTimeException异常

public class CustomException extends RuntimeException{
    public CustomException(String message){
        super(message);
    }
}

(2)同上进行异常处理

@ExceptionHandler(CustomException.class)
public R<String> exceptionHandler(CustomException ex) {
    return R.error(ex.getMessage());
}
posted @ 2023-06-18 23:30  Bepowerful  阅读(47)  评论(0)    收藏  举报