天天看點

Spring(二) 基于注解的IOC配置

0.基于注解的IOC配置

我們需要明确,基于注解的IOC配置和基于xml配置所要實作的功能都是一樣的,都是為了降低程式之間的耦合性,隻是配置的形式不一樣

在以後的實際開發中,要根據實際情況選擇不同的配置方式

1.環境搭建

1.1第一步:建立maven工程

1.2第二步:導入spring包,在pom.xml中進行相關的配置

Spring(二) 基于注解的IOC配置

注意:我們建立的是maven工程,是以相關的jar包都是自動導入

但是,如果建立的是普通的java工程的話,要手動的加入下列jar包,以保證注解功能可以正常使用

aop的jar包使用注解時必須導入

需要配置告知spring在建立容器時要掃描的包,配置所需要的标簽不是在beans限制中

而是在一個名為context的名稱空間和限制中

Spring(二) 基于注解的IOC配置

1.3 第三步:建立spring的xml配置檔案并開啟對注解的支援

  • 1 在根路徑下建立一個任意名稱的xml檔案(在maven工程中,一般放在resources中)
  • 2 導入配置檔案需要的限制

    限制檔案位置:spring-framework-5.0.2.RELEASE-dist\spring-framework-5.0.2.RELEASE\docs\spring-framework-reference\html5\core.html

    Spring(二) 基于注解的IOC配置
    Spring(二) 基于注解的IOC配置

    2.常用注解

    2.1注解分類:

    1.用于建立對象的:

    他們的作用和xml配置檔案中< bean >标簽中實作的功能是一樣的

    2.用于注入資料的:

    他們的作用和xml配置檔案中< bean >标簽中的< property >的作用是一樣的

    3.用于改變作用範圍的:

    他們的作用是在bean标簽中使用scope熟悉感的功能是一樣的

    4.和生命周期相關的(了解) :

    他們的作用就和在bean标簽中使用init-method和destroy-method的作用是一樣的

    2.2注解的詳解

    2.2.1 用于建立對象的注解

    Spring(二) 基于注解的IOC配置
    1 @Component
  • 作用:用于把目前對象存入spring容器中
  • 屬性:value :用于指定bean的id,當不寫時,它的預設值是目前類名且首字母改小寫
  • 如果沒有導入context的配置檔案

    會報錯:NoSuchBeanDefinitionException: No bean named ‘accountServiceImpl’ available

  1. @Controller @Service @Repository
  • @Controller :一般用在表現層
  • @Service :一般用在業務層
  • @Repository :一般用于持久層 (三個可以互換使用)
  • 以上三個注解他們的作用和屬性與Component的屬性和作用是一模一樣的

    他們三個是spring架構為我們提供給明确的三層使用的注解,使我們的三層對象更加清晰

    (如果注解中有且隻有一個屬性要指派時,且名稱是 value,value在指派是可以不寫)

2.2.2 用于注入資料的注解

Spring(二) 基于注解的IOC配置

[email protected]

作用:
  • 自動按照類型注入,隻要容器中有唯一的一個bean對象類型和要注入的類型比對,就可以注入成功
  • 如果ioc容器中沒有任何bea的類型和要注入的變量類型比對則報錯
  • 出現位置:可以是成員變量上,也可以是方法上
  • 細節: 在使用注解注入時,set方法可以省略

如果ioc容器中有多個與要注入類型一緻的bean類型, 首先按照類型圈定出比對的對象

再使用變量名稱作為bean的id,在圈定出的對象中繼續查找,如果有一樣的就注入成功,如果沒有就會報錯

Spring(二) 基于注解的IOC配置

2. @Qualifier @Resource

@Qualifier

  • 作用:在按照類型注入的基礎之上,再按照名稱注入,在給類成員注入時,不能單獨使用(與Autowired配合使用),但是在給方法參數注入時可以
  • 屬性:value :用于指定注入bean的id

@Resource

  • 作用:直接按照bean的id使用,可以獨立使用
  • 屬性 :name:用于指定bean的id

以上三個注解都隻能注入其他bean類型的資料,基本類型和String類型不能注入

另外,集合類型的注入隻能通過xml來實作

@value

  • 作用:用于注入基本類型和String類型的資料
  • 屬性:value:用于指定資料的值,它可以使用spring中的SpEl(spring的EL表達式)

    SpEl寫法: ${表達式}

2.2.3 用于改變作用範圍的注解

Spring(二) 基于注解的IOC配置

[email protected]

  • 作用: 用于指定bean的作用範圍
  • 屬性: value:指定範圍的取值 常用取值:singleton,prototype

2.2.4 和生命周期相關的(了解)

Spring(二) 基于注解的IOC配置
  • @PreDestroy :用于指定銷毀方法
  • @PostConstruct :用于指定初始化方法

2.2.5 sprig注解和xml配置的選擇問題

Spring(二) 基于注解的IOC配置

問題:

在通過以上注解配置程式以後,我們發現,還是離不開xml配置檔案,我們還有一些關鍵的配置還需要在xml中進行配置,例如對資料源的配置等,接下來,介紹一些新注解,進一步 脫離xml檔案

3.spring新注解

[email protected]

  • 作用:指定目前類是一個配置類,當建立容器時,會從該類上加載注解
  • 擷取容器時需要使用AnnotationConfigApplicationContext(有@Configuration注解的類.class)

我們已經把配置檔案用類來代替了,但是如何配置建立容器時要掃描的包呢? 請看下一個注解。

[email protected]

  • 作用:用于通過注解指定spring在建立容器時要掃描的包
  • 屬性: value :它和basePackages的作用是一樣的,都是用于指定建立容器時所需要掃描的包
  • 使用此注解就等同于在xml中配置了:

    < context:component-scan base-package=“com.itcast”>< /context:component-scan>

我們已經配置好了要掃描的包,但是資料源和 JdbcTemplate 對象如何從配置檔案中移除呢? 請看下一個注解。

[email protected]

  • 作用: 用于把目前方法的傳回值作為bean對象存入spring的ioc容器中

    該注解隻能寫在方法上,表明使用此方法建立一個對象,并放入spring容器中

  • 屬性: name :用于指定bean的id (不寫的時候,預設值是目前方法的名稱)
  • 細節:當我們使用注解配置方法時,如果方法有參數,spring架構會去容器中查找有沒有可用的bean對象,查找的方式和Autowired注解的作用是一樣的
/*
    * 用于建立一個queryRunner對象
    * */
    @Bean(name = "runner")
    public QueryRunner createQueryRunner(DataSource dataSource)
    {
        return new QueryRunner(dataSource);
    }
    /*
    * 建立資料源對象
    * */
    @Bean("dataSource")
    public DataSource createDataSource() {

        ComboPooledDataSource ds = new ComboPooledDataSource();
        try {
            ds.setDriverClass(driver);
            ds.setJdbcUrl(url);
            ds.setUser(username);
            ds.setPassword(password);
            return ds;
        } catch (Exception e) {
            throw new RuntimeException(e);
        }
    }
           

我們已經把資料源從配置檔案中移除了,此時可以删除 bean.xml 了。 但是由于沒有了配置檔案,建立資料源的配置又都寫死在類中了。如何把它們配置出來呢? 請看下一個注解。

[email protected]

  • 作用:用于指定properties檔案的位置,
  • 屬性:value:指定檔案的名稱和路徑,如果是在類路徑下,則需要使用關鍵字:classpath 表示類路徑下
@PropertySource("classpath:jdbcConfig.properties")
public class SpringConfiguration {
    @Value("${jdbc.driver}")
    private String driver;
    @Value("${jdbc.url}")
    private String url;
    @Value("${jdbc.username}")
    private String username;
    @Value("${jdbc.password}")
    private String password;

  /*
    * 建立資料源對象
    * */
@Bean("dataSource")
    public DataSource createDataSource() {
          ComboPooledDataSource ds = new ComboPooledDataSource();
                  try {
                         ds.setDriverClass(driver);
                         ds.setJdbcUrl(url);
                         ds.setUser(username);
                         ds.setPassword(password);
                          return ds;
                       } catch (Exception e) {
                                throw new RuntimeException(e);
                    }
         }

/*
*jdbc.properties配置檔案
*/
jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/spring01
jdbc.username=root
jdbc.password=root

           

[email protected]

  • 作用:用于在主配置類中導入其他的配置類,在引入其他配置類時,可以不用再寫@Configuration注解
  • 屬性: value :用于指定其他配置類的位元組碼
  • 當我們使用import之後,有Import注解的類,就是主配置類,導入的都是子配置類