用于类上的注解
@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());
}
标签:false,String,注释,必须,注解,true
From: https://www.cnblogs.com/liu-jin/p/17490024.html