当前位置: 首页 > news >正文

spring中的@PropertySource注解详解

一、核心功能与作用

@PropertySource是Spring框架中用于加载外部配置文件的核心注解,主要作用是将属性文件(如.properties.yml)的键值对加载到Spring的Environment环境中,实现配置与代码的解耦。其核心价值包括:

  • 外部化配置管理:将数据库连接、API密钥等敏感信息从代码中剥离,存储到外部文件。

  • 多环境适配:支持按环境加载不同配置文件(如开发、生产环境)。

  • 动态注入:结合@Value注解或Environment接口直接获取配置值。

在这里插入图片描述


二、注解属性与语法

@PropertySource的源码定义如下:

@Target(ElementType.TYPE)
@Retention(RetentionPolicy.RUNTIME)
@Repeatable(PropertySources.class)
public @interface PropertySource {String name() default "";        // 属性源名称(默认自动生成)String[] value();                // 文件路径(支持classpath:、file:等协议)boolean ignoreResourceNotFound() default false; // 忽略文件未找到错误String encoding() default "";     // 文件编码(解决中文乱码问题)Class<? extends PropertySourceFactory> factory() default PropertySourceFactory.class; // 自定义工厂类
}

关键属性解析:

  1. value
    指定配置文件路径,支持多种协议:
    @PropertySource("classpath:config/db.properties")  // 类路径
    @PropertySource("file:/etc/app/config.yml")        // 文件系统路径
    @PropertySource("https://config-server.com/env.properties") // 远程资源
    
  2. ignoreResourceNotFound
    设置为true时,若文件不存在不会抛出异常(默认false,严格模式)。
  3. factory
    自定义属性源工厂,用于解析非标准格式(如YAML、JSON)的配置文件。

三、使用场景与最佳实践

  1. 基础用法:加载单一配置文件

    @Configuration
    @PropertySource("classpath:application.properties")
    public class AppConfig {@Value("${db.url}")private String dbUrl;
    }
    
    • 文件内容自动注入Environment,通过@Value("${key}")environment.getProperty("key")获取。
  2. 多文件与动态环境配置

    @Configuration
    @PropertySources({@PropertySource("classpath:default.properties"),@PropertySource("classpath:env/${spring.profiles.active}.properties")
    })
    public class MultiEnvConfig {}
    
    • 通过${spring.profiles.active}动态加载环境相关配置。

    • 优先级规则:后加载的文件覆盖先加载的同名属性。

  3. 自定义配置格式支持(如YAML)

    public class YamlPropertySourceFactory implements PropertySourceFactory {@Overridepublic PropertySource<?> createPropertySource(String name, EncodedResource resource) {YamlPropertiesFactoryBean factory = new YamlPropertiesFactoryBean();factory.setResources(resource.getResource());Properties properties = factory.getObject();return new PropertiesPropertySource(name, properties);}
    }// 使用示例
    @Configuration
    @PropertySource(value = "classpath:config.yml", factory = YamlPropertySourceFactory.class)
    public class YamlConfig {}
    
    • 通过实现PropertySourceFactory接口解析非标准格式文件。

四、底层原理与执行流程

  1. 加载时机
    在Spring容器启动阶段,ConfigurationClassPostProcessor会扫描所有@Configuration类,解析@PropertySource注解。
  2. 处理流程
    • 资源定位:根据value属性查找文件。

    • 资源解析:使用默认或自定义的PropertySourceFactory将文件转换为PropertySource对象。

    • 注册环境:将生成的PropertySource添加到EnvironmentPropertySources列表中。


五、注意事项与常见问题

  1. 编码问题
    若配置文件含中文,需显式指定encoding="UTF-8"

  2. 资源路径匹配

    • 使用classpath*:前缀可扫描多个JAR包中的同名文件。

    • 支持Ant风格路径模式(如config/*.properties)。

  3. @ConfigurationProperties配合
    更推荐结合@ConfigurationProperties实现类型安全的配置绑定:

    @Configuration
    @PropertySource("classpath:redis.properties")
    @ConfigurationProperties(prefix = "redis")
    public class RedisConfig {private String host;private int port;
    }
    

总结

@PropertySource通过标准化配置加载机制,使Spring应用具备高度灵活的外部化配置能力。开发者可根据需求选择基础用法或通过自定义工厂扩展,同时需关注属性优先级、编码规范及多环境适配等关键点。对于复杂场景,建议结合@Profile@Conditional实现动态配置管理。


spring5.x讲解介绍

netty与tomcat的比较

相关文章:

  • 记录裁员后的半年前端求职经历
  • 【氮化镓】GaN在不同电子能量损失的SHI辐射下的损伤
  • 歌曲《忘尘谷》基于C语言的歌曲调性检测技术解析
  • Linux常用命令详解(下):打包压缩、文本编辑与查找命令
  • Codeforces Round 1024 (Div. 2)(A-D)
  • 五、Hive表类型、分区及数据加载
  • [Java][Leetcode simple] 189. 轮转数组
  • 中国黄土高原中部XF剖面磁化率和粒度数据
  • 信息系统项目管理师-软考高级(软考高项)​​​​​​​​​​​2025最新(十八)
  • 数据库分区与分表详解
  • Java实现MCP server,配合DeepSeek和达梦数据库,实现基于企业数据库的智能问答
  • MACH-ETH:汽车网络接口的卓越之选
  • 数据库实验报告 系统E-R图设计 2
  • 堆复习(C语言版)
  • Matlab 234-锂电池充放电仿真
  • DVWA在线靶场-SQL注入部分
  • ultralytics框架计算大中小目标检测精度
  • K8s进阶之一文搞懂PV,PVC及SC
  • 技术文章: PCB基板介电常数的温度系数
  • [Java实战]Spring Boot 整合 Redis(十八)
  • 支持企业增强战略敏捷更好发展,上海市领导密集走访外贸外资企业
  • 老人将房产遗赠给外孙,三个女儿却认为遗嘱应无效,法院判了
  • 为证明我爸是我爸,我将奶奶告上法庭
  • 《致1999年的自己》:千禧之年的你在哪里?
  • 武汉旅游体育集团有限公司原党委书记、董事长董志向被查
  • 中国海外发展:今年前4个月销售665.8亿元,花费305亿元拿地