首页 > 其他分享 >注解

注解

时间:2023-06-18 23:33:28浏览次数:42  
标签:false String 注释 必须 注解 true

用于类上的注解

@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

相关文章

  • Java 注解
    一、Java注解(Annotation)简介从Java5版本之后可以在源代码中嵌入一些补充信息,这种补充信息称为注解(Annotation),是Java平台中非常重要的一部分。注解都是@符号开头的,例如:在学习方法重写时使用过的@Override注解。同Class和Interface一样,注解也属于一种类型。Annotation......
  • springboot中自定义注解在service方法中,aop失效
    问题描述写了个自定义注解,但是该注解只会出现在serviece层中的方法中。启动发现aop未拦截到问题原因:调用service中的xx()方法时,Spring的动态代理帮我们动态生成了一个代理的对象,暂且叫他$XxxxService。所以调用xx()方法实际上是代理对象$XxxxService调用的。但是在xx()方法内调用同......
  • 3. @RequestMapping注解
    1.@RequestMapping注解的功能‍@RequestMapping注解的作用就是将请求和处理请求的控制器方法关联起来,建立映射关系。‍SpringMVC接收到指定的请求,就会来找到在映射关系中对应的控制器方法来处理这个请求‍2.@RequestMapping注解的位置‍@RequestMapping标识一个......
  • Java官方笔记10注解
    注解注解的作用:Informationforthecompiler—Annotationscanbeusedbythecompilertodetecterrorsorsuppresswarnings.Compile-timeanddeployment-timeprocessing—Softwaretoolscanprocessannotationinformationtogeneratecode,XMLfiles,ands......
  • @Import注解
    1.前言 在之前关于springBoot自动装配一文里,曾经写过里面有一个很关键的注解,就是@Import,它让springBoot可以将spring.factories中的各组件的配置类加载到spring容器中,那么今天来讲下关于这个注解的一些了解。2.import注解讲解2.1@Import注解的作用向spring容器中添加实......
  • 注解 annotation
    内置注解@Override:重写@Deprecated:不推荐使用的@SupperessWarnings("all"):镇压警告元注解用于负责注解其他注解@Target:解释被描述的注解的使用范围@Retention:解释需要在什么级别保存被描述的注解信息(SOURCE<CLASS<RUNTIME)@Document:解释被描述的注解被......
  • Spring注解开发
    注解开发介绍:注解开发是spring的强项,实际开发过程中更多使用的是注解注入而非bean标签注入xml和注解开发的对比:xml可以适用任何场景,结构清晰,维护方便注解不是自己提供的类使用不了,开发简单方便建议使用xml和注解整合开发xml管理Bean注解完成属性注入使用过程中,可以......
  • 实现一个权限校验注解
    什么是注解?Java注解是附加在代码中的一些元信息,用于编译和运行时进行解析和使用,起到说明、配置的功能。注解不会影响代码的实际逻辑,仅仅起到辅助性的作用。包含在java.lang.annotation包中。注解的定义类似于接口的定义,使用@interface来定义,定义一个方法即为注解类型定义了一个元......
  • 采用注解方式-HTTP Status 404 – Not Found 或者 采用web
    采用注解方式->HTTPStatus404–NotFound或者采用web.xml方式->cannotresolvetheclassinthetag运行一个简单的servlet程序,分别采用了两种方式对servlet进行映射,均报错。1⃣️采用Annotation方式@WebServlet(name="DownloadServlet",urlPatterns="/download"......
  • SpringBoot使用自定义日志注解,配置切面
    1.使用技巧以下是需要注意的部分:在环绕通知中使用ProceedingJoinPoint,控制目标方法的运行。在其他通知类型中使用JoinPoint。如果使用JoinPoint则必须位于参数的第一位。ProceedingJoinPoint中有特殊的方法proceed()。当有多个切面时,使用@Order(11)来指定注解的优先级。......