SpringBoot学习(二)——属性注入

78 篇文章 0 订阅
10 篇文章 0 订阅

Springboot配置

方法一
  • 新建jdbc.properties文件,写入配置
jdbc.driverClassName=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/book
jdbc.username=root
jdbc.password=root
  • 创建配置类JdbcConfig.java,使用@Value注解将属性注入,并进行Bean配置
//表明当前类为配置类
@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;
    // 将dataSource方法声明分为一个注册的Bean的方法  Spring 会自动调用该方法  将方法的返回值加入到Spring容器中
    @Bean
    public DataSource dataSource(){
        DruidDataSource dataSource = new DruidDataSource();
        dataSource.setDriverClassName(driverClassName);
        dataSource.setUrl(url);
        dataSource.setUsername(username);
        dataSource.setPassword(password);
        return  dataSource;
    }

}
  • 编写Controller进行测试,使用@Autowired注解注入dataSource。
@RestController
public class HelloController {

    @Autowired
    private DataSource dataSource;
    @RequestMapping("/hello")
    public String Hello() {

        System.out.println("dataSource :"+dataSource);
        return "helloSpringBoot!";
    }

}
  • 测试结果

在这里插入图片描述

方法二
  • 在application.properties里面写入配置
jdbc.driverClassName=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/book
jdbc.username=root
jdbc.password=123456
  • 创建JdbcProperties.java配置类,添加get和set方法。
//表明当前类是一个属性读取类 所读取的配置文件的名称必须是application.properties
//同时prefix 表明所有的属性的前缀
@ConfigurationProperties(prefix = "jdbc")
public class JdbcProperties {

    private String  driverClassName;

    private String  url;

    private String username;

    private String password;

    public String getDriverClassName() {
        return driverClassName;
    }

    public void setDriverClassName(String driverClassName) {
        this.driverClassName = driverClassName;
    }

    public String getUrl() {
        return url;
    }

    public void setUrl(String url) {
        this.url = url;
    }

    public String getUsername() {
        return username;
    }

    public void setUsername(String username) {
        this.username = username;
    }

    public String getPassword() {
        return password;
    }

    public void setPassword(String password) {
        this.password = password;
    }
}
  • 使用set方法注入属性
//表明当前类为配置类
@Configuration
// 指定属性配置文件的路径
@EnableConfigurationProperties(JdbcProperties.class)
public class JdbcConfig1 {

    @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;
    }

}
  • 测试

在这里插入图片描述

第三种
  • 删除 JdbcProperties中的@ConfigurationProperties(prefix = “jdbc”)

  • 删除@EnableConfigurationProperties(JdbcProperties.class)注解

  • 在方法上添加@ConfigurationProperties(prefix = “jdbc”)

@Configuration
// 指定属性配置文件的路径
//@EnableConfigurationProperties(JdbcProperties.class)
public class JdbcConfig1 {

    @Bean
    @Co	nfigurationProperties(prefix = "jdbc")
    public DataSource dataSource(){
        return  new DruidDataSource();
    }

}
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Spring Boot中,属性注入可以通过不同的方式实现。一种常见的方式是使用`@ConfigurationProperties`注解。通过将该注解应用于一个类上,可以将`application.properties`或`application.yml`文件中定义的属性注入Java类中。这种注入是通过Java属性的setter方法进行的。 另外一种方式是通过在`@Bean`方法上使用`@ConfigurationProperties`注解。在这种情况下,Spring Boot会自动调用该`@Bean`方法,并将相关属性通过setter方法注入到对应的Bean中。需要注意的是,被注入属性的类必须具有对应属性的setter方法。 为了观察被注入属性,你可以通过访问`http://localhost:8080/source/show`来查看。这个URL将展示被注入属性信息。另外,还可以使用`@ConfigurationProperties`注解进行批量注入属性,以方便地注入多个属性。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [SpringBoot属性注入](https://blog.csdn.net/Nicholas_GUB/article/details/120997989)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [SpringBoot 属性注入](https://blog.csdn.net/2301_77025309/article/details/130994152)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

张宜强

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值