配置类替换bean.xml

SpringConfiguration

使用一个配置类来代替bean.xml, 其作用和bean.xml相同

需要通过AnnotationConfigApplicationContext获取容器对象

ApplicationContext ac = new AnnotationConfigApplicationContext(SpringConfiguration.class);

@Configuration注解

指定当前类是配置类

@Configuration
public class SpringConfiguration {
}

@ComponentScan注解

用于指定Spring在创建容器时需要扫描的包 , 等同于<context:component-scan base-package="xxx.xx"/>

value / basePackages : 需要扫描的(多个)包名

@Configuration
@ComponentScan(basePackages = "com.study.spring")
public class SpringConfiguration {
}

@Bean注解

用于把当前方法的返回值作为Bean对象存入Spring容器中

name : 指定Bean的id, 默认值为当前方法名称

@Bean(name = "runner")
@Scope("prototype")
public QueryRunner createQueryRunner(@Qualifier("spring") DataSource ds){
	return new QueryRunner(ds);
}

@Scope("prototype"): 设置多例.

@Qualifier("spring"): 设置传入的Beanid

@Bean(name = "spring")
public DataSource createDataSource(){
    ComboPooledDataSource ds = new ComboPooledDataSource();
    try {
        ds.setDriverClass("com.mysql.cj.jdbc.Driver");
        ds.setJdbcUrl("jdbc:mysql://localhost:3306/spring?serverTimezone=UTC");
        ds.setUser("root");
        ds.setPassword("Hhn004460");
        return ds;
    } catch (PropertyVetoException e) {
        e.printStackTrace();
        return null;
    }
}

注意:当我们使用注解配置方法时, 当方法有参数, Spring会去容器中查找有没有Bean对象, 查找方式和@Autowired注解作用一样.


@Import注解

用于导入其他的配置类

value : 其他配置类字节码数组

@Import(JdbcConfiguration.class)
public class SpringConfiguration {
}

@PropertySource注解

用于指定properties文件的位置

value : 指定文件的名称和路径

​ 关键字: classpath , 表示在类路径下

@PropertySource("classpath:jdbcConfig.properties")
public class SpringConfiguration {
}

案例

主配置类

@Configuration
@ComponentScan(basePackages = "com.study.spring")
@Import(JdbcConfiguration.class)
@PropertySource("classpath:jdbcConfig.properties")
public class SpringConfiguration {

}

其他配置类

public class JdbcConfiguration {

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

    @Bean(name = "runner")
    @Scope("prototype")
    public QueryRunner createQueryRunner(DataSource ds){
        return new QueryRunner(ds);
    }

    @Bean(name = "ds")
    public DataSource createDataSource(){
        ComboPooledDataSource ds = new ComboPooledDataSource();
        try {
            ds.setDriverClass(driver);
            ds.setJdbcUrl(url);
            ds.setUser(user);
            ds.setPassword(password);
            return ds;
        } catch (PropertyVetoException e) {
            e.printStackTrace();
            return null;
        }
    }
}

配置文件

jdbc.driver=com.mysql.cj.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/spring?serverTimezone=UTC
jdbc.user=root
jdbc.password=Hhn004460
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值