基于Java类的配置 基于Java配置选项,可以编写大多数的Spring不用配置XML,但有几个基于Java的注释的帮助下解释。
@Configuration & @Bean 注解: 带有 @Configuration 的注解类表示这个类可以使用 Spring IoC 容器作为 bean 定义的来源(相当于XML中的beans )。@Bean 注解告诉 Spring,一个带有 @Bean 的注解方法将返回一个对象,该对象应该被注册为在 Spring 应用程序上下文中的 bean。最简单可行的 @Configuration 类如下所示:
1 2 3 4 5 6 7 8 9 package com.tutorialspoint;import org.springframework.context.annotation.*;@Configuration public class HelloWorldConfig { @Bean public HelloWorld helloWorld () { return new HelloWorld(); } }
上面的代码等价于以下的XML配置
1 2 3 <beans > <bean id ="helloWorld" class ="com.tutorialspoint.HelloWorld" /> </beans >
在这里,带有 @Bean 注解的方法名称作为 bean 的 ID,它创建并返回实际的 bean。你的配置类可以声明多个 @Bean。一旦定义了配置类,你就可以使用 AnnotationConfigApplicationContext 来加载并把他们提供给 Spring 容器,如下所示:
1 2 3 4 5 6 7 public static void main (String[] args) { ApplicationContext ctx = new AnnotationConfigApplicationContext(HelloWorldConfig.class); HelloWorld helloWorld = ctx.getBean(HelloWorld.class); helloWorld.setMessage("Hello World!" ); helloWorld.getMessage(); }
可以加载各种配置类,如下所示:
1 2 3 4 5 6 7 8 9 public static void main (String[] args) { AnnotationConfigApplicationContext ctx = new AnnotationConfigApplicationContext(); ctx.register(AppConfig.class, OtherConfig.class); ctx.register(AdditionalConfig.class); ctx.refresh(); MyService myService = ctx.getBean(MyService.class); myService.doStuff(); }
例子 HelloWorldConfig.java
1 2 3 4 5 6 7 8 9 package com.tutorialspoint;import org.springframework.context.annotation.*;@Configuration public class HelloWorldConfig { @Bean public HelloWorld helloWorld () { return new HelloWorld(); } }
HelloWorld.java
1 2 3 4 5 6 7 8 9 10 package com.tutorialspoint;public class HelloWorld { private String message; public void setMessage (String message) { this .message = message; } public void getMessage () { System.out.println("Your Message : " + message); } }
MainApp.java
1 2 3 4 5 6 7 8 9 10 11 12 package com.tutorialspoint;import org.springframework.context.ApplicationContext;import org.springframework.context.annotation.*;public class MainApp { public static void main (String[] args) { ApplicationContext ctx = new AnnotationConfigApplicationContext(HelloWorldConfig.class); HelloWorld helloWorld = ctx.getBean(HelloWorld.class); helloWorld.setMessage("Hello World!" ); helloWorld.getMessage(); } }
一旦你完成了创建所有的源文件并添加所需的额外的库后,我们就可以运行该应用程序。你应该注意这里不需要配置文件。如果你的应用程序一切都正常,将输出以下信息:
1 Your Message : Hello World!
注入Bean的依赖性 当 @Beans 依赖对方时,表达这种依赖性非常简单,只要有一个 bean 方法调用另一个,如下所示:
1 2 3 4 5 6 7 8 9 10 11 12 13 package com.tutorialspoint;import org.springframework.context.annotation.*;@Configuration public class AppConfig { @Bean public Foo foo () { return new Foo(bar()); } @Bean public Bar bar () { return new Bar(); } }
@Import 注解: @import 注解允许从另一个配置类中加载 @Bean 定义。考虑 ConfigA 类,如下所示:
1 2 3 4 5 6 7 @Configuration public class ConfigA { @Bean public A a () { return new A(); } }
你可以在另一个 Bean 声明中导入上述 Bean 声明,如下所示:
1 2 3 4 5 6 7 8 @Configuration @Import (ConfigA.class)public class ConfigB { @Bean public B a () { return new A(); } }
现在,当实例化上下文时,不需要同时指定 ConfigA.class 和 ConfigB.class,只有 ConfigB 类需要提供,如下所示:
1 2 3 4 5 6 7 public static void main (String[] args) { ApplicationContext ctx = new AnnotationConfigApplicationContext(ConfigB.class); A a = ctx.getBean(A.class); B b = ctx.getBean(B.class); }
生命周期回调 @Bean 注解支持指定任意的初始化和销毁的回调方法,就像在 bean 元素中 Spring 的 XML 的初始化方法和销毁方法的属性:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 public class Foo { public void init () { } public void cleanup () { } } @Configuration public class AppConfig { @Bean (initMethod = "init" , destroyMethod = "cleanup" ) public Foo foo () { return new Foo(); } }
指定 Bean 的范围:
默认范围是单实例,但是你可以重写带有 @Scope 注解的该方法,如下所示:
1 2 3 4 5 6 7 8 @Configuration public class AppConfig { @Bean @Scope ("prototype" ) public Foo foo () { return new Foo(); } }