天天看点

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注解的类,就是主配置类,导入的都是子配置类