鍍金池/ 教程/ Java/ 基于 Java 的配置
Spring MVC Hello World 例子
事務(wù)管理
JDBC 框架概述
MVC 框架教程
Spring 自動(dòng)裝配 ‘byName’
Spring 中的自定義事件
Spring 編程式事務(wù)管理
環(huán)境設(shè)置
概述
Spring 中 SQL 的存儲(chǔ)過(guò)程
體系結(jié)構(gòu)
Spring 中的事件處理
Spring 靜態(tài)頁(yè)面例子
基于注解的配置
依賴注入
Spring 自動(dòng)裝配 ‘byType’
Spring 由構(gòu)造函數(shù)自動(dòng)裝配
Spring @Qualifier 注釋
Spring ApplicationContext 容器
Spring 中基于 AOP 的 XML架構(gòu)
Bean 的生命周期
IoC 容器
注入內(nèi)部 Beans
Spring JDBC 示例
Spring 基于構(gòu)造函數(shù)的依賴注入
Spring @Required 注釋
Hello World 實(shí)例
Bean 定義
Sping 的 BeanFactory 容器
Spring 頁(yè)面重定向例子
Bean 定義繼承
Spring 中基于 AOP 的 @AspectJ
注入集合
Beans 自動(dòng)裝配
Spring 異常處理例子
Spring 聲明式事務(wù)管理
Spring @Autowired 注釋
基于 Java 的配置
Spring MVC 表單處理例子
Spring——Bean 后置處理器
使用 Log4J 記錄日志
Spring 基于設(shè)值函數(shù)的依賴注入
Spring JSR-250 注釋
Bean 的作用域
Spring 框架的 AOP

基于 Java 的配置

到目前為止,你已經(jīng)看到如何使用 XML 配置文件來(lái)配置 Spring bean。如果你熟悉使用 XML 配置,那么我會(huì)說(shuō),不需要再學(xué)習(xí)如何進(jìn)行基于 Java 的配置是,因?yàn)槟阋_(dá)到相同的結(jié)果,可以使用其他可用的配置。

基于 Java 的配置選項(xiàng),可以使你在不用配置 XML 的情況下編寫(xiě)大多數(shù)的 Spring,但是一些有幫助的基于 Java 的注解,解釋如下:

@Configuration 和 @Bean 注解

帶有 @Configuration 的注解類(lèi)表示這個(gè)類(lèi)可以使用 Spring IoC 容器作為 bean 定義的來(lái)源。@Bean 注解告訴 Spring,一個(gè)帶有 @Bean 的注解方法將返回一個(gè)對(duì)象,該對(duì)象應(yīng)該被注冊(cè)為在 Spring 應(yīng)用程序上下文中的 bean。最簡(jiǎn)單可行的 @Configuration 類(lèi)如下所示:

package com.tutorialspoint;
import org.springframework.context.annotation.*;
@Configuration
public class HelloWorldConfig {
   @Bean 
   public HelloWorld helloWorld(){
      return new HelloWorld();
   }
}

上面的代碼將等同于下面的 XML 配置:

<beans>
   <bean id="helloWorld" class="com.tutorialspoint.HelloWorld" />
</beans>

在這里,帶有 @Bean 注解的方法名稱(chēng)作為 bean 的 ID,它創(chuàng)建并返回實(shí)際的 bean。你的配置類(lèi)可以聲明多個(gè) @Bean。一旦定義了配置類(lèi),你就可以使用 AnnotationConfigApplicationContext 來(lái)加載并把他們提供給 Spring 容器,如下所示:

public static void main(String[] args) {
   ApplicationContext ctx = 
   new AnnotationConfigApplicationContext(HelloWorldConfig.class); 
   HelloWorld helloWorld = ctx.getBean(HelloWorld.class);
   helloWorld.setMessage("Hello World!");
   helloWorld.getMessage();
}

你可以加載各種配置類(lèi),如下所示:

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();
}

例子

讓我們?cè)谇‘?dāng)?shù)奈恢檬褂?Eclipse IDE,然后按照下面的步驟來(lái)創(chuàng)建一個(gè) Spring 應(yīng)用程序:

步驟 描述
1 創(chuàng)建一個(gè)名稱(chēng)為 SpringExample 的項(xiàng)目,并且在創(chuàng)建項(xiàng)目的 src 文件夾中創(chuàng)建一個(gè)包 com.tutorialspoint
2 使用 Add External JARs 選項(xiàng),添加所需的 Spring 庫(kù),解釋見(jiàn) Spring Hello World Example 章節(jié)。
3 因?yàn)槟闶鞘褂没?java 的注解,所以你還需要添加來(lái)自 Java 安裝目錄的 CGLIB.jar 和可以從 asm.ow2.org 中下載的 ASM.jar 庫(kù)。
4 com.tutorialspoint 包中創(chuàng)建 Java 類(lèi) HelloWorldConfig、HelloWorldMainApp。
5 最后一步是創(chuàng)建的所有 Java 文件和 Bean 配置文件的內(nèi)容,并運(yùn)行應(yīng)用程序,解釋如下所示。

這里是 HelloWorldConfig.java 文件的內(nèi)容:

package com.tutorialspoint;
import org.springframework.context.annotation.*;
@Configuration
public class HelloWorldConfig {
   @Bean 
   public HelloWorld helloWorld(){
      return new HelloWorld();
   }
}

這里是 HelloWorld.java 文件的內(nèi)容:

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 文件的內(nèi)容:

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();
   }
}

一旦你完成了創(chuàng)建所有的源文件并添加所需的額外的庫(kù)后,我們就可以運(yùn)行該應(yīng)用程序。你應(yīng)該注意這里不需要配置文件。如果你的應(yīng)用程序一切都正常,將輸出以下信息:

Your Message : Hello World!

注入 Bean 的依賴性

當(dāng) @Beans 依賴對(duì)方時(shí),表達(dá)這種依賴性非常簡(jiǎn)單,只要有一個(gè) bean 方法調(diào)用另一個(gè),如下所示:

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();
   }
}

這里,foo Bean 通過(guò)構(gòu)造函數(shù)注入來(lái)接收參考基準(zhǔn)。現(xiàn)在,讓我們看到一個(gè)正在執(zhí)行的例子:

例子:

讓我們?cè)谇‘?dāng)?shù)奈恢檬褂?Eclipse IDE,然后按照下面的步驟來(lái)創(chuàng)建一個(gè) Spring 應(yīng)用程序:

步驟 描述
1 創(chuàng)建一個(gè)名稱(chēng)為 SpringExample 的項(xiàng)目,并且在創(chuàng)建項(xiàng)目的 src 文件夾中創(chuàng)建一個(gè)包 com.tutorialspoint。
2 使用 Add External JARs 選項(xiàng),添加所需的 Spring 庫(kù),解釋見(jiàn) Spring Hello World Example 章節(jié)。
3 因?yàn)槟闶鞘褂没?java 的注解,所以你還需要添加來(lái)自 Java 安裝目錄的 CGLIB.jar 和可以從 asm.ow2.org 中下載的 ASM.jar 庫(kù)。
4 com.tutorialspoint 包中創(chuàng)建 Java 類(lèi) TextEditorConfig、TextEditor、SpellCheckerMainApp。
5 最后一步是創(chuàng)建的所有 Java 文件和 Bean 配置文件的內(nèi)容,并運(yùn)行應(yīng)用程序,解釋如下所示。

這里是 TextEditorConfig.java 文件的內(nèi)容:

package com.tutorialspoint;
import org.springframework.context.annotation.*;
@Configuration
public class TextEditorConfig {
   @Bean 
   public TextEditor textEditor(){
      return new TextEditor( spellChecker() );
   }
   @Bean 
   public SpellChecker spellChecker(){
      return new SpellChecker( );
   }
}

這里是 TextEditor.java 文件的內(nèi)容:

package com.tutorialspoint;
public class TextEditor {
   private SpellChecker spellChecker;
   public TextEditor(SpellChecker spellChecker){
      System.out.println("Inside TextEditor constructor." );
      this.spellChecker = spellChecker;
   }
   public void spellCheck(){
      spellChecker.checkSpelling();
   }
}

下面是另一個(gè)依賴的類(lèi)文件 SpellChecker.java 的內(nèi)容:

package com.tutorialspoint;
public class SpellChecker {
   public SpellChecker(){
      System.out.println("Inside SpellChecker constructor." );
   }
   public void checkSpelling(){
      System.out.println("Inside checkSpelling." );
   }

}

下面是 MainApp.java 文件的內(nèi)容:

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(TextEditorConfig.class);

      TextEditor te = ctx.getBean(TextEditor.class);

      te.spellCheck();
   }
}

一旦你完成了創(chuàng)建所有的源文件并添加所需的額外的庫(kù)后,我們就可以運(yùn)行該應(yīng)用程序。你應(yīng)該注意這里不需要配置文件。如果你的應(yīng)用程序一切都正常,將輸出以下信息:

Inside SpellChecker constructor.
Inside TextEditor constructor.
Inside checkSpelling.

@Import 注解:

@import 注解允許從另一個(gè)配置類(lèi)中加載 @Bean 定義??紤] ConfigA 類(lèi),如下所示:

@Configuration
public class ConfigA {
   @Bean
   public A a() {
      return new A(); 
   }
}

你可以在另一個(gè) Bean 聲明中導(dǎo)入上述 Bean 聲明,如下所示:

@Configuration
@Import(ConfigA.class)
public class ConfigB {
   @Bean
   public B a() {
      return new A(); 
   }
}

現(xiàn)在,當(dāng)實(shí)例化上下文時(shí),不需要同時(shí)指定 ConfigA.class 和 ConfigB.class,只有 ConfigB 類(lèi)需要提供,如下所示:

public static void main(String[] args) {
   ApplicationContext ctx = 
   new AnnotationConfigApplicationContext(ConfigB.class);
   // now both beans A and B will be available...
   A a = ctx.getBean(A.class);
   B b = ctx.getBean(B.class);
}

生命周期回調(diào)

@Bean 注解支持指定任意的初始化和銷(xiāo)毀的回調(diào)方法,就像在 bean 元素中 Spring 的 XML 的初始化方法和銷(xiāo)毀方法的屬性:

public class Foo {
   public void init() {
      // initialization logic
   }
   public void cleanup() {
      // destruction logic
   }
}

@Configuration
public class AppConfig {
   @Bean(initMethod = "init", destroyMethod = "cleanup" )
   public Foo foo() {
      return new Foo();
   }
}

指定 Bean 的范圍:

默認(rèn)范圍是單實(shí)例,但是你可以重寫(xiě)帶有 @Scope 注解的該方法,如下所示:

@Configuration
public class AppConfig {
   @Bean
   @Scope("prototype")
   public Foo foo() {
      return new Foo();
   }
}