springBoot属性注入的几种方式

Spring Boot默认识别application.properties和application.yml文件。介绍了三种属性注入方式:一是不使用默认文件,用jdbc.properties和JdbcConfig.java,较麻烦;二是用application.properties,创建属性配置类JdbcProperties,代码更清晰;三是最简洁的方式,用application.properties和JdbcConfig。可按需选择。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

因为springBoot是默认识别application.properties和application.yml文件的。
第一种,我们不使用上面两者:
数据源配置文件为jdbc.properties

jdbc.driverClassName=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://127.0.0.1:3306/e3mall
jdbc.username=root
jdbc.password=root

java配置文件JdbcConfig.java

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

    @Value("${jdbc.driverClassName}")
    String driverClassName;
    @Value("${jdbc.url}")
    String url;
    @Value("${jdbc.username}")
    String username;
    @Value("${jdbc.password}")
    String password;

    @Bean
    public DataSource dataSource() {
        DruidDataSource dataSource = new DruidDataSource();
        dataSource.setDriverClassName(driverClassName);
        dataSource.setUrl(url);
        dataSource.setUsername(username);
        dataSource.setPassword(password);
        return dataSource;
    }
}

这种配置可以实现,但是麻烦,不得springboot的精髓

第二种,使用application.properties

jdbc.driverClassName=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://127.0.0.1:3306/e3mall
jdbc.username=root
jdbc.password=root

创建属性配置类 JdbcProperties

    @ConfigurationProperties(prefix = "jdbc")
    @Data
    public class JdbcProperties {
        String driverClassName;
        String url;
        String username;
        String password;
    }
改变JdbcConfig类

    @Configuration
    @EnableConfigurationProperties(JdbcProperties.class)
    public class JdbcConfig {
        @Bean
        public DataSource dataSource(JdbcProperties jdbc) {
            DruidDataSource dataSource = new DruidDataSource();
            dataSource.setDriverClassName(jdbc.getDriverClassName());
            dataSource.setUrl(jdbc.getUrl());
            dataSource.setUsername(jdbc.getUsername());
            dataSource.setPassword(jdbc.getPassword());
            return dataSource;
        }
    }

这种方式将属性配置单独读取成一个类,代码更清晰简洁

第三种,最简洁最优雅的方式
配置文件application.properties

  jdbc.driverClassName=com.mysql.jdbc.Driver
    jdbc.url=jdbc:mysql://127.0.0.1:3306/e3mall
    jdbc.username=root
    jdbc.password=root

类文件JdbcConfig

@Configuration
public class JdbcConfig {
    @Bean
    @ConfigurationProperties(prefix = "jdbc")
    public DataSource dataSource() {
        return new DruidDataSource();
    }
}

以上三种大家可以根据项目需要进行选择使用

Spring Boot 提供了多种注入 Bean 的方式,使得依赖管理变得更加方便。主要有以下几种: 1. **构造函数注入**(Constructor Injection):这是最常见的注入方式,通过将 Bean 的构造函数参数映射到 Spring 容器里的配置。例如,在 Application 类中创建一个 Service 实例: ```java @Service public class MyService { private final MyRepository repository; @Autowired public MyService(MyRepository repository) { this.repository = repository; } } ``` 2. **setter 方法注入**(Setter Injection):当构造函数不适合时,可以使用 setter 方法注入Spring 会自动查找匹配的 setter 方法并设置其值: ```java @Service public class MyService { private MyRepository repository; // ... public void setRepository(MyRepository repository) { this.repository = repository; } } // XML 配置或 Java Config 中 @Autowired private void setRepository(MyRepository repository) { this.myService.setRepository(repository); } ``` 3. **@Autowired/@Resource 注解**:这两个注解用于简化自动装配过程,它们会在候选 Bean 中寻找与属性类型匹配的对象。 4. **Spring Expression Language (SpEL)**:允许你在属性值上使用表达式语言来动态地确定依赖项。 5. **@Qualifier注解**:对于有多个同名Bean的情况,可以使用Qualifier指定需要的具体实例。 6. **@Inject注解**:这是 Guice 模块中的一种注入方式,但在 Spring Boot 中不太常用,通常用于与第三方 IoC 库集成。 7. **使用@ComponentScan扫描包**:自动发现并注册带有特定注解(如@Service、@Repository等)的类。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值