Spring的Java配置方式—@Configuration和@Bean實現Java配置


Java配置是Spring4.x推薦的配置方式,可以完全替代xml配置。

1、@Configuration 和 @Bean
Spring的Java配置方式是通過 @Configuration 和 @Bean 注解實現的:
a、@Configuration 作用於類上,相當於一個xml配置文件
b、@Bean 作用於方法上,相當於xml配置中的<bean>

2、Java配置示例
演示通過Java配置的方式進行Spring配置,並且實現Spring IOC功能。
2.1) 創建工程以及導入依賴(Maven)

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <groupId>com.lynch</groupId>
    <artifactId>spring-config</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <packaging>war</packaging>

    <dependencies>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-webmvc</artifactId>
            <version>4.3.7.RELEASE</version>
        </dependency>
        <!-- 連接池 -->
        <dependency>
            <groupId>com.jolbox</groupId>
            <artifactId>bonecp-spring</artifactId>
            <version>0.8.0.RELEASE</version>
        </dependency>
    </dependencies>
    <build>
        <finalName>${project.artifactId}</finalName>
        <plugins>
            <!-- 資源文件拷貝插件 -->
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-resources-plugin</artifactId>
                <configuration>
                    <encoding>UTF-8</encoding>
                </configuration>
            </plugin>
            <!-- java編譯插件 -->
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-compiler-plugin</artifactId>
                <configuration>
                    <source>1.8</source>
                    <target>1.8</target>
                    <encoding>UTF-8</encoding>
                </configuration>
            </plugin>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-war-plugin</artifactId>
                <version>2.6</version>
                <configuration>
                    <failOnMissingWebXml>false</failOnMissingWebXml>
                </configuration>
            </plugin>
        </plugins>
        <pluginManagement>
            <plugins>
                <!-- 配置Tomcat插件 -->
                <plugin>
                    <groupId>org.apache.tomcat.maven</groupId>
                    <artifactId>tomcat7-maven-plugin</artifactId>
                    <version>2.2</version>
                </plugin>
            </plugins>
        </pluginManagement>
    </build>
</project>


2.2) 編寫User Model對象

package com.lynch.javaconfig;

public class User {
    private String username;
    private String password;
    private Integer age;

    public String getUsername() {
        return username;
    }

    public void setUsername(String username) {
        this.username = username;
    }

    public String getPassword() {
        return password;
    }

    public void setPassword(String password) {
        this.password = password;
    }

    public Integer getAge() {
        return age;
    }

    public void setAge(Integer age) {
        this.age = age;
    }

}


2.3) 編寫UserDAO,用於模擬與數據庫的交互(注意此DAO沒有打注解)

package com.lynch.javaconfig;

import java.util.ArrayList;
import java.util.List;

public class UserDAO {

    public List<User> queryUserList() {
        // 模擬數據庫的查詢
        List<User> result = new ArrayList<User>();
        for (int i = 0; i < 10; i++) {
            User user = new User();
            user.setUsername("username_" + i);
            user.setPassword("password_" + i);
            user.setAge(i + 1);
            result.add(user);
        }
        
        return result;
    }

}


2.4) 編寫UserService,用於實現User數據操作業務邏輯(聲明service注解,並自動注入dao對象)

package com.lynch.javaconfig;

import java.util.List;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

@Service
public class UserService {
    // 注入Spring容器中的bean對象
    @Autowired
    private UserDAO userDAO;

    public List<User> queryUserList() {
        // 調用userDAO中的方法進行查詢
        return this.userDAO.queryUserList();
    }

}

 

2.5) 編寫SpringConfig,用於實例化Spring容器
打上@Configuration注解,同時打上@ComponentScan配置掃描的包。

@Bean用於向容器中注入對象,如果在UserDao類前面打上@Repository注解就不用@Bean方式

package com.lynch.javaconfig;

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.Configuration;

//通過@Configuration注解來表明該類是一個Spring的配置,相當於一個xml文件
@Configuration
@ComponentScan(basePackages = "com.lynch.javaconfig")
public class SpringConfig {
    
    // 通過@Bean注解來表明是一個Bean對象,相當於xml中的<bean>
    @Bean
    public UserDAO getUserDAO() {
        return new UserDAO(); // 直接new對象做演示
    }

}

注意:方法名是作為返回對象的名字的,因此一般不帶get,也就是上述放入spring容器的bean的name為getUserDAO

2.6) 編寫測試方法,用於啟動Spring容器

package com.lynch.javaconfig;

import java.util.List;

import org.springframework.context.annotation.AnnotationConfigApplicationContext;

public class Application {

    public static void main(String[] args) {
        // 通過Java配置來實例化Spring容器
        AnnotationConfigApplicationContext context = new AnnotationConfigApplicationContext(SpringConfig.class);

        // 在Spring容器中獲取Bean對象
        UserService userService = context.getBean(UserService.class);

        // 調用對象中的方法
        List<User> list = userService.queryUserList();
        for (User user : list) {
            System.out.println(user.getUsername() + ", " + user.getPassword() + ", " + user.getPassword());
        }

        // 銷毀該容器
        context.destroy();
    }

}


執行結果:

username_0, password_0, password_0
username_1, password_1, password_1
username_2, password_2, password_2
username_3, password_3, password_3
username_4, password_4, password_4
username_5, password_5, password_5
username_6, password_6, password_6
username_7, password_7, password_7
username_8, password_8, password_8
username_9, password_9, password_9

 

總結:從以上的示例中可以看出,使用Java代碼就完美的替代xml配置文件,並且結構更加的清晰。

3、使用方法
Spring對Java配置的支持是由@Configuration注解和@Bean注解來實現的。
@Bean注解將會實例化、配置和初始化一個新對象,這個對象將由Spring的IoC容器來管理。@Bean聲明所起到的作用與<bean/> 元素類似。
@Configuration注解的類表示這個類的主要目的是作為bean定義的資源。被@Configuration聲明的類可以通過在同一個類的內部調用@bean方法來設置嵌入bean的依賴關系。

@Configuration    
public class AppConfig{    
    @Bean    
    public MyService myService() {    
        return new MyServiceImpl();    
    }    
}

對於上面的@Beans配置文件,等同於下面的XML配置文件:

<beans>    
    <bean id="myService" class="com.somnus.services.MyServiceImpl"/>    
</beans>

 

上述配置方式的實例化方式如下:利用AnnotationConfigApplicationContext 類進行實例化

public static void main(String[] args) {    
    ApplicationContext ctx = new AnnotationConfigApplicationContext(AppConfig.class);    
    MyService myService = ctx.getBean(MyService.class);    
    myService.doStuff();    
}

 

要使用組件掃描,僅需用@Configuration進行注解即可:

@Configuration    
@ComponentScan(basePackages = "com.lynch")    
public class AppConfig  {    
    ...    
} 

在上面的例子中,com.lynch包首先會被掃描到,然后在容器內查找被@Component 聲明的類,找到后將這些類按照Sring bean定義進行注冊。

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM