Spring-@AliasFor注解的使用和作用
众所周知@AliasFor注解也是Spring框架中的其中一个,此注解主要用于声明注解属性的别名。
传统使用中,它有三种不同的应用场景。
第一种场景
注解内的别名使用,在我们所熟知的很多注解中都使用了。比如@RequestMapping注解当中,通过源码就可以清楚的看到。
通过源码可以理解:@AliasFor(value=“xxx”)和@AliasFor(attribute=“xxx”)是等价的。当然在使用此注解的时候,其中的path与value的值必须是相等的的!
第二种场景
它主要是为了为其它注解别名操作。
那我们@RequestMapping注解为例,应用此场景。
自定义注解如下:
@Retention(RetentionPolicy.RUNTIME)
@Target({ElementType.METHOD})
@RequestMapping
public @interface MyRequestMappingConfig {
@AliasFor(annotation = RequestMapping.class,value = "value")
String v() default "";
@AliasFor(annotation = RequestMapping.class,value = "path")
String url() default "";
}
在控制层进行测试自定义注解操作:
@MyRequestMappingConfig(url = "getAOP1")
public String getAop1() {
return "Hello AOP1";
}
符合我们预期的结果:
第三种场景
它主要是为了为其它注解传递别名操作(与第二种方法类似)。
那我们参考第二种场景,进行演示操作。
自定义注解如下:
@Retention(RetentionPolicy.RUNTIME)
@Target({ElementType.METHOD})
@RequestMapping
public @interface MyRequestMappingConfig {
// 传递别名操作,通过attribute属性,而在AliasFor中,attribute与value是相通的,因此url等价于url1
@AliasFor(annotation = RequestMapping.class,attribute = "path")
String url1() default "";
}
在控制层进行测试自定义注解操作:
@MyRequestMappingConfig(url1 = "getAOP1")
public String getAop1() {
return "Hello AOP1";
}
通过代码测试,得出的结果符合我们预期。
以上就是我们的别名注解作用和使用!