Spring framework 3.1 开始支持”@Enable 模块驱动“。比如常用@EnableWebMvc、@EnableAsync、@EnableAspectJAutoProxy等。实现自定义Enable模块方式有两种,注解方式、编程方式。本文将通过这两种方式来讲解怎么实现自定义Enable模块。
Spring框架@Enable 模块有哪些| @Enable 注解模块 | 激活模块 |
|---|---|
| @EnableWebMvc | Web MVC 模块 |
| @EnableTransactionManagement | 事务管理模块 |
| @EnableAsync | 异步处理模块 |
| @EnableCaching | Caching 模块 |
| @EnableAspectJAutoProxy | AspectJ 代理模块 |
| @EnableMBeanExport | JMX 模块 |
实现一个配置类MyEnableConfiguration自定义@Enable注解,并导入配置类MyEnableConfiguration demo
MyEnableConfiguration
public class MyConfig {
private String jdkVersion = "V1.0";
@Override
public String toString() {
return "MyConfig{" +
"jdkVersion='" + jdkVersion + ''' +
'}';
}
public String getJdkVersion() {
return jdkVersion;
}
public void setJdkVersion(String jdkVersion) {
this.jdkVersion = jdkVersion;
}
}
@Configuration(proxyBeanMethods = false)
public class MyEnableConfiguration {
@Bean
public MyConfig myConfig() {
return new MyConfig();
}
}
EnableMyConfig 注解
@documented
@Target({ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
@import(MyEnableConfiguration.class)
public @interface EnableMyConfig {
}
运行
@EnableMyConfig
public class EnableApplicationDemo {
public static void main(String[] args) {
AnnotationConfigApplicationContext context = new AnnotationConfigApplicationContext();
context.register(EnableApplicationDemo.class);
context.refresh();
MyConfig myConfig = context.getBean(MyConfig.class);
System.out.println(myConfig);
}
}
官方参考案例:@EnableWebMvc
@Retention(RetentionPolicy.RUNTIME)
@Target({ElementType.TYPE})
@documented
@import({DelegatingWebMvcConfiguration.class})
public @interface EnableWebMvc {
}
@Configuration(
proxyBeanMethods = false
)
public class DelegatingWebMvcConfiguration extends WebMvcConfigurationSupport {
private final WebMvcConfigurerComposite configurers = new WebMvcConfigurerComposite();
.............
}
编程方式
实现步骤
实现一个实现importSelector或者importBeanDefinitionRegistrar类自定义@Enable注解,并导入 demo
MyConfigimport
public class MyConfigimport implements importSelector {
@Override
public String[] selectimports(Annotationmetadata importingClassmetadata) {
return new String[]{"com.github.bearboy80.spring.enable.MyConfig"};
}
}
public class MyConfig {
private String jdkVersion = "V1.0";
@Override
public String toString() {
return "MyConfig{" +
"jdkVersion='" + jdkVersion + ''' +
'}';
}
public String getJdkVersion() {
return jdkVersion;
}
public void setJdkVersion(String jdkVersion) {
this.jdkVersion = jdkVersion;
}
}
EnableMyConfig 注解
@documented
@Target({ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
@import(MyConfigimport.class)
@import(MyEnableConfiguration.class)
public @interface EnableMyConfig {
}
运行
@EnableMyConfig
public class EnableApplicationDemo {
public static void main(String[] args) {
AnnotationConfigApplicationContext context = new AnnotationConfigApplicationContext();
context.register(EnableApplicationDemo.class);
context.refresh();
MyConfig myConfig = context.getBean(MyConfig.class);
System.out.println(myConfig);
}
}
总结
本文只是简单的介绍通过注解或者编程方式实现一个简单的@Enable模块。



