当前位置: 首页 > 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的比较

http://www.xdnf.cn/news/399673.html

相关文章:

  • 【SSM-SSM整合】将Spring、SpringMVC、Mybatis三者进行整合;本文阐述了几个核心原理知识点,附带对应的源码以及描述解析
  • 《步进电机最小转速终极指南:从理论到实战,突破低速极限的5大秘技》
  • 未来技术展望:光子量子计算集成与连续变量可视化
  • 第二章、物理层
  • 基于CNN-BiLSTM-Attention的回归预测模型!
  • 基于注意力机制与iRMB模块的YOLOv11改进模型—高效轻量目标检测新范式
  • properties和yaml 文件加载指定配置文件的注解
  • MySQL 8.0 OCP 英文题库解析(三)
  • Java:编程世界的常青树与数字化转型的基石
  • VM中 ubuntu 网卡不显示
  • 机器学习第六讲:向量/矩阵 → 数据表格的数学表达,如Excel表格转数字阵列
  • HDFS客户端操作
  • 堆复习(C语言版)
  • 首屏优化,webpack插件用于给html中js自动添加异步加载属性
  • Linux操作系统从入门到实战(六)Linux开发工具(上)详细介绍什么是软件包管理器,Linux下如何进行软件和软件包的安装、升级与卸载
  • 探索边缘计算:赋能物联网的未来
  • 一.Gitee基本操作
  • 2025年阿里云ACP人工智能高级工程师认证模拟试题(附答案解析)
  • Vue:插值表达
  • 如何在 Bash 中使用 =~ 操作符 ?
  • 单词短语0512
  • C++色彩博弈的史诗:红黑树
  • 关于大语言模型的困惑度(PPL)指标优势与劣势
  • 菊厂0510面试手撕题目解答
  • spdlog日志格式化 标志全指南
  • Java详解LeetCode 热题 100(14):LeetCode 56. 合并区间(Merge Intervals)详解
  • 【网络安全】SQL注入
  • pdf 不是扫描件,但却无法搜索关键词【问题尝试解决未果记录】
  • 用短说社区搭建的沉浸式生活方式分享平台
  • Redis+Caffeine构建高性能二级缓存