注解

1|0用于类上的注解

1|0@Accessors

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

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

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

prefix属性可以忽略前缀

1|1lombok注解

1|0@Setter

1|0@getter

1|0@Tostring

1|0@EqualsAndHushcode

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

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

1|0@RequiredArgsContructor

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

1|0@Data

​ 包含以上五个注解

1|0@NoArgsContructor

1|0@AllArgsContructor

1|2MybatisPlus中的注解

1|0@TableName("tb_")

1|0@TableId (value=" ",id排序)

1|0@Tablefield

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

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

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

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

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

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

1|0@TableLogic

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

1|0@Version

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

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

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

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

1|0@NotEmpty

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

1|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); }

1|4异常类注解

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

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

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

1|0@RestControllerAdvice(annotations = {RestController.class})

1|0@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()); }

__EOF__

本文作者liuliu的小家
本文链接https://www.cnblogs.com/liu-jin/p/17490024.html
关于博主:hello~好久不见,喜欢的话点个赞吧
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角推荐一下。您的鼓励是博主的最大动力!
posted @   Bepowerful  阅读(23)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
点击右上角即可分享
微信分享提示