一.使用元注解定义注解的范围和保留时间
@Target
定义注解的作用范围
例:@Target({ ElementType.TYPE}) //表示作用于类、接口(包括注解类型) 或enum声明
参数 | 说明 |
---|---|
CONSTRUCTOR | 用于描述构造器 |
FIELD | 用于描述域 |
LOCAL_VARIABLE | 用于描述局部变量 |
METHOD | 用于描述方法 |
PACKAGE | 用于描述包 |
PARAMETER | 用于描述参数 |
TYPE | 用于描述类、接口(包括注解类型) 或enum声明 |
@Retention
定义注解的保留时间
例:@Retention(RetentionPolicy.RUNTIME) //表示在运行时有效
参数 | 说明 |
---|---|
SOURCE | 在源文件中有效 |
CLASS | 在class文件中有效 |
RUNTIME | 在运行时有效 |
二.示例代码
注解
/***
* @description <执行操作是否需要token>
**/
@Target({ElementType.METHOD, ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
public @interface UserLoginToken {
boolean required() default true;//参数,默认值为true
}
使用注解
@UserLoginToken(required = true) //使用注解,required是默认值可省略
@PostMapping("/save")
@ApiOperation(value = "新增或修改用户", notes = "", httpMethod = "POST")
public Result save(User user) {
...//具体操作
}
三.关于自定义注解的具体操作
例如 如何判断方法是否带有注解 等,请查看HandlerInterceptor拦截器