Spring-boot中读取config配置文件的两种方式

本文介绍 Spring Boot 中如何读取核心配置文件 application.properties 和自定义配置文件 author.properties 的内容。通过 @Value 注解和 Environment 接口读取核心配置文件;使用 ConfigurationProperties 注解读取自定义配置文件。

了解过spring-Boot这个技术的,应该知道Spring-Boot的核心配置文件application.properties,当然也可以通过注解自定义配置文件的信息。


Spring-Boot读取配置文件的方式:

一.读取核心配置文件信息application.properties的内容

     核心配置文件是指在resources根目录下的application.properties或application.yml配置文件,读取这两个配置文件的方法有两种,都比较简单。


核心配置文件application.properties内容如下:

[java]  view plain  copy
  1. test.msg=Hello World SpringBoot  

方式一:使用@Value方式(常用)

[java]  view plain  copy
  1. <span style="font-size:18px;">package Solin.controller;  
  2.   
  3. import org.springframework.beans.factory.annotation.Value;  
  4. import org.springframework.web.bind.annotation.RequestMapping;  
  5. import org.springframework.web.bind.annotation.RestController;  
  6.   
  7. @RestController  
  8. public class WebController {  
  9.     @Value("${test.msg}")  
  10.     private String msg;  
  11.       
  12.     @RequestMapping("/index1")   
  13.     public String index1(){  
  14.         return "方式一:"+msg;  
  15.     }  
  16. }</span>  
注意:在@Value的${}中包含的是核心配置文件中的键名。在Controller类上加@RestController表示将此类中的所有视图都以JSON方式显示,类似于在视图方法上加@ResponseBody。
访问:http://localhost:8088/index1时得到:"方式一:Hello World SpringBoot"


方式二:使用Environment方式

[java]  view plain  copy
  1. <span style="font-size:18px;">package Solin.controller;  
  2.   
  3. import org.springframework.beans.factory.annotation.Autowired;  
  4. import org.springframework.beans.factory.annotation.Value;  
  5. import org.springframework.core.env.Environment;  
  6. import org.springframework.web.bind.annotation.RequestMapping;  
  7. import org.springframework.web.bind.annotation.RestController;  
  8.   
  9. @RestController  
  10. public class WebController {  
  11.     @Autowired  
  12.     private Environment env;  
  13.       
  14.     @RequestMapping("/index2")   
  15.     public String index2(){  
  16.         return "方式二:"+env.getProperty("test.msg");  
  17.     }  
  18. }  
  19. </span>  
注意:这种方式是依赖注入Evnironment来完成,在创建的成员变量private Environment env上加上@Autowired注解即可完成依赖注入,然后使用env.getProperty("键名")即可读取出对应的值。
访问:http://localhost:8088/index2时得到:"方式二:Hello World SpringBoot"


二.读取自定义配置文件信息,例如:author.properties

为了不破坏核心文件的原生态,但又需要有自定义的配置信息存在,一般情况下会选择自定义配置文件来放这些自定义信息,这里在resources目录下创建配置文件author.properties

resources/author.properties内容如下:

[java]  view plain  copy
  1. author.name=Solin  
  2. author.age=22  

创建管理配置的实体类:
[java]  view plain  copy
  1. package Solin.controller;  
  2.   
  3. import org.springframework.boot.context.properties.ConfigurationProperties;  
  4. import org.springframework.context.annotation.Configuration;  
  5. import org.springframework.stereotype.Component;  
  6.   
  7. //加上注释@Component,可以直接其他地方使用@Autowired来创建其实例对象  
  8. @Component  
  9. @ConfigurationProperties(prefix = "author",locations = "classpath:author.properties")     
  10. public class MyWebConfig{  
  11.     private String name;  
  12.     private int age;  
  13.     public String getName() {  
  14.         return name;  
  15.     }  
  16.     public void setName(String name) {  
  17.         this.name = name;  
  18.     }  
  19.     public int getAge() {  
  20.         return age;  
  21.     }  
  22.     public void setAge(int age) {  
  23.         this.age = age;  
  24.     }  
  25. }  

注意:
    在@ConfigurationProperties注释中有两个属性:
locations:指定配置文件的所在位置
prefix:指定配置文件中键名称的前缀(我这里配置文件中所有键名都是以author.开头)
    使用@Component是让该类能够在其他地方被依赖使用,即使用@Autowired注释来创建实例。


创建测试Controller

[java]  view plain  copy
  1. package Solin.controller;  
  2.   
  3. import org.springframework.beans.factory.annotation.Autowired;  
  4. import org.springframework.stereotype.Controller;  
  5. import org.springframework.web.bind.annotation.RequestMapping;  
  6. import org.springframework.web.bind.annotation.ResponseBody;  
  7.   
  8. @Controller    
  9. public class ConfigController {  
  10.     @Autowired  
  11.     private MyWebConfig conf;  
  12.       
  13.     @RequestMapping("/test")   
  14.     public @ResponseBody String test() {  
  15.         return "Name:"+conf.getName()+"---"+"Age:"+conf.getAge();   
  16.     }  
  17. }  

注意:由于在Conf类上加了注释@Component,所以可以直接在这里使用@Autowired来创建其实例对象。

访问:http://localhost:8088/test时得到:"Name:Solin---Age:22"

### Spring Boot Starter 库的功能对比 `nacos-config-spring-boot-starter` 和 `spring-cloud-starter-alibaba-nacos-config` 是用于集成 Nacos 配置管理功能的两种不同方式。以下是它们的主要功能差异和适用场景: #### 功能差异 1. **核心职责** - `nacos-config-spring-boot-starter` 主要专注于提供轻量级的支持,允许开发者通过简单的配置来加载 Nacos 中存储的应用程序属性文件[^1]。 - `spring-cloud-starter-alibaba-nacos-config` 则更全面地集成了 Spring Cloud 生态系统中的特性,支持动态刷新配置以及与其他微服务框架组件无缝协作。 2. **动态刷新能力** - 使用 `nacos-config-spring-boot-starter` 时,如果需要实现配置项变更后的自动更新,则可能需额外编写逻辑处理监听器事件并手动触发重新加载过程[^2]。 - 而对于 `spring-cloud-starter-alibaba-nacos-config` 来说,默认情况下已经内置了对 Actuator 终端 `/actuator/refresh` 的支持,能够轻松完成热部署而无需重启应用实例[^3]。 3. **与Spring生态系统的融合度** - 前者独立于任何特定版本的 Spring 或其扩展模块工作良好;但是当项目规模扩大到涉及多个分布式子系统之间相互调用的时候可能会显得力不从心[^4]。 - 后者作为阿里巴巴官方推荐使用的 starter ,天然具备更好的兼容性和稳定性,在复杂的云原生架构下表现尤为突出——比如配合 Sentinel 进行流量防护或者借助 Dubbo 实现高性能RPC通信等功能都可以很方便地接入进来形成统一的技术栈解决方案[^5]. #### 适用场景分析 - 如果当前业务相对简单只需要读取远程配置中心的数据源即可满足需求的话可以选择前者即单独引入 nacos-config-spring-boot-starter 即可快速启动运行; - 对于那些正在构建大型企业级平台并且希望利用完整的 spring cloud alibaba 工具链优势的企业来说则应该优先考虑后者也就是 spring-cloud-starter-alibaba-nacos-config 。它不仅提供了强大的开箱即用型功能还简化了很多繁琐的手动操作流程从而让工程师可以把更多精力放在解决实际问题上面而不是浪费时间维护基础设施代码之上 。 ```java // 示例:如何在 application.yml 文件中启用 spring-cloud-starter-alibaba-nacos-config spring: application: name: example-service cloud: nacos: config: server-addr: localhost:8848 # 设置Nacos服务器地址 ``` ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值