元注解
组合注解
创建一个组合注解
传递属性给元注解
实验
创建一个Maven项目
pom.xml
application.yml
App.java
GetMappingShadow.java
RestControllerShadow.java
项目结构
运行结果
参考资料
所谓的元注解:其实就是可以注解到别的注解上的注解。而被注解的注解我们就称之为组合注解。这样,组合注解同时具备元注解的功能!
元注解
Spring4.0的许多注解都可以用作meta annotation(元注解)。元注解是一种使用在别的注解上的注解。这意味着我们可以使用Spring的注解组合成一个我们自己的注解。
类似于:@Documented, @Component, @RequestMapping, @Controller, @ResponseBody等等
对于元注解,是Spring框架中定义的部分,都有特定的含义。我们并不能修改,但是对于组合注解,我们完全可以基于自己的定义进行实现。
组合注解
自定义注解或组合注解是从其他的Spring元注解创建的。这种注解分为两类:
只是为了编码简单将多个注解组合成一个注解;
可以定义一个可复用的注解,这个注解可以解决问题,但是不用记住所有单独的注解。
创建一个组合注解
创建一个组合注解,并且提供注解value属性。
@Target(ElementType.TYPE)
@Retention(RetentionPolicy.RUNTIME)
@Documented
@Controller
@ResponseBody
public @interface RestControllerShadow {
String value() default "";
}
传递属性给元注解
而当我们使用的元注解需要配置属性的时候,可以通过如下指定:
@AliasFor(annotation = RequestMapping.class)
String name() default "";
实验
创建一个Maven项目
pom.xml
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
application.yml
spring:
application:
name: test-08
server:
port: 9090
App.java
package com.freud.test.springboot;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
/**
* @author Freud
*/
@SpringBootApplication
@RestControllerShadow
public class App {
@GetMappingShadow("/hi")
public String get() {
return "Composite Annotation";
}
public static void main(String[] args) {
SpringApplication.run(App.class, args);
}
}
GetMappingShadow.java
package com.freud.test.springboot;
import java.lang.annotation.Documented;
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
import org.springframework.core.annotation.AliasFor;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
/**
* A copy of @GetMapping
*
* @author Freud
*/
@Target(ElementType.METHOD)
@Retention(RetentionPolicy.RUNTIME)
@Documented
@RequestMapping(method = RequestMethod.GET)
public @interface GetMappingShadow {
@AliasFor(annotation = RequestMapping.class)
String name() default "";
@AliasFor(annotation = RequestMapping.class)
String[] value() default {};
@AliasFor(annotation = RequestMapping.class)
String[] path() default {};
@AliasFor(annotation = RequestMapping.class)
String[] params() default {};
@AliasFor(annotation = RequestMapping.class)
String[] headers() default {};
@AliasFor(annotation = RequestMapping.class)
String[] consumes() default {};
@AliasFor(annotation = RequestMapping.class)
String[] produces() default {};
}
RestControllerShadow.java
package com.freud.test.springboot;
import java.lang.annotation.Documented;
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.ResponseBody;
/**
* A copy of @RestController
*
* @author Freud
*/
@Target(ElementType.TYPE)
@Retention(RetentionPolicy.RUNTIME)
@Documented
@Controller
@ResponseBody
public @interface RestControllerShadow {
String value() default "";
}
项目结构
运行结果
参考资料
Spring Boot Reference Guide : http://docs.spring.io/spring-boot/docs/current-SNAPSHOT/reference/htmlsingle/
Spring4.0系列4-Meta Annotation(元注解): Spring4.0系列4-Meta Annotation(元注解)