_Spring IOC相关注解运用——下篇

2023-11-19 23:11:10 浏览数 (1)

一、@Configuration

    此时基于注解的IOC配置已经完成,但是我们依然离不开Spring的xml配置文件。接下来我们脱离bean.xml,使用纯注解实现IOC。         在真实开发中,我们一般还是会保留xml配置文件,很多情况下使用配置文件更加方便。     纯注解实现IOC需要一个Java类代替xml文件。这个Java类上方需要添加@Configuration,表示该类是一个配置类,作用是代替配置文件。

SpringConfig配置类 

代码语言:javascript复制
package com.example;

import org.springframework.context.annotation.Configuration;

@Configuration
public class SpringConfig {

}

二、@ComponentScan

1. 说明

作用:指定spring在初始化容器时扫描的包。 位置:配置类上方

SpringConfig配置类 

代码语言:javascript复制
package com.example;

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

@Configuration
@ComponentScan("com.example")
public class SpringConfig {

}

2. 测试方法

代码语言:javascript复制
    // 测试纯注解
    @Test
    public void t4(){
        ApplicationContext ac = new AnnotationConfigApplicationContext(SpringConfig.class);
        StudentService service = ac.getBean("studentService",StudentService.class);
        System.out.println(service.findById(8));
    }

3. 运行结果

OK,确实可以。 

三、@PropertySource

1. 说明

作用:代替配置文件中的 <context:property-placeholder> 扫描配置文件 位置:配置类上方 注意:配置文件位置前要加关键字 classpath

JdbcConfig配置类 

代码语言:javascript复制
package com.example;

import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.PropertySource;

import java.sql.Connection;
import java.sql.DriverManager;

@Configuration
@PropertySource("classpath:db.properties")
public class JdbcConfig {

    @Value("${jdbc.username}")
    private String username;

    @Value("${jdbc.password}")
    private String password;


    @Override
    public String toString() {
        return "JdbcConfig[ "  
                "username='"   username   '''  
                ", password='"   password   '''  
                " ]";
    }
}

2. 测试方法

代码语言:javascript复制
    // 测试纯注解扫描jdbc
    @Test
    public void t5(){
        ApplicationContext ac = new AnnotationConfigApplicationContext(JdbcConfig.class);
        JdbcConfig config = (JdbcConfig) ac.getBean("jdbcConfig");
        System.out.println(config);
    }

3. 测试结果

OK,也是没有问题的。 

四、@Bean

1. 说明

  • 作用:将方法的返回值对象放入Spring容器中。如果想将第三方类的对象放入容器,可以使用@Bean
  • 位置:配置类的方法上方。
  • 属性:name:给bean对象设置id
  • 注意:@Bean修饰的方法如果有参数,spring会根据参数类型从容器中查找可用对象。
  • 举例:如果想将jdbc连接对象放入Spring容器,我们无法修改Connection源码添加@Component,此时就需要使用将@Bean该对象放入Spring容器

2. 添加驱动依赖

在pom.xml文件添加依赖

代码语言:javascript复制
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>8.0.27</version>
        </dependency>

3. 将Connection对象放入Spring容器

代码语言:javascript复制
    @Bean("connection")
    public Connection getConnection(){
        try{
            Class.forName("com.mysql.cj.jdbc.Driver");
            return DriverManager.getConnection("jdbc:mysql:///mysql","root","666666");
        }catch (Exception e){
            e.printStackTrace();
            return null;
        }
    }

4. 测试

测试方法

代码语言:javascript复制
    // 测试注解bean
    @Test
    public void t6(){
        ApplicationContext ac = new AnnotationConfigApplicationContext(SpringConfig.class);
        Connection connection = (Connection) ac.getBean("connection");
        System.out.println(connection);
    }

运行结果

添加描述

OK,也是可以成功获取连接的 

五、@Import

1. 说明

作用:如果配置过多,会有多个配置类,该注解可以为主配置类导入其他配置类 位置:主配置类上方 上述我们讲的,SpringConfig应当为主配置类,所以该注解应当添加在SpringConfig类的上方

代码语言:javascript复制
package com.example;

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


@Configuration
@ComponentScan("com.example")
@Import(JdbcConfig.class)
public class SpringConfig {

}

2. 测试方法

代码语言:javascript复制
    // 测试纯注解
    @Test
    public void t4(){
        ApplicationContext ac = new AnnotationConfigApplicationContext(SpringConfig.class);
        JdbcConfig jdbcConfig = ac.getBean("jdbcConfig",JdbcConfig.class);
        System.out.println(jdbcConfig);
    }

3. 运行结果

我正在参与2023腾讯技术创作特训营第三期有奖征文,组队打卡瓜分大奖!

0 人点赞