详解Spring Boot 属性配置和使用

发布时间 - 2026-01-11 01:47:26    点击率:

spring Boot 允许通过外部配置让你在不同的环境使用同一应用程序的代码,简单说就是可以通过配置文件来注入属性或者修改默认的配置。

Spring Boot 支持多种外部配置方式

这些方式优先级如下:

  1. 命令行参数
  2. 来自java:comp/env的JNDI属性
  3. Java系统属性(System.getProperties())
  4. 操作系统环境变量
  5. RandomValuePropertySource配置的random.*属性值
  6. jar包外部的application-{profile}.properties或application.yml(带spring.profile)配置文件
  7. jar包内部的application-{profile}.properties或application.yml(带spring.profile)配置文件
  8. jar包外部的application.properties或application.yml(不带spring.profile)配置文件
  9. jar包内部的application.properties或application.yml(不带spring.profile)配置文件
  10. @Configuration注解类上的@PropertySource
  11. 通过SpringApplication.setDefaultProperties指定的默认属性

命令行参数

通过Java -jar app.jar --name="Spring" --server.port=9090方式来传递参数。

参数用--xxx=xxx的形式传递。

可以使用的参数可以是我们自己定义的,也可以是Spring Boot中默认的参数。

很多人可能会关心如web端口如何配置这样的问题,这些都是Spring Boot中提供的参数,部分可用参数如下:

# LOGGING
logging.path=/var/logs
logging.file=myapp.log
logging.config= # location of config file (default classpath:logback.xml for logback)
logging.level.*= # levels for loggers, e.g. "logging.level.org.springframework=DEBUG" (TRACE, DEBUG, INFO, WARN, ERROR, FATAL, OFF)

# EMBEDDED SERVER CONFIGURATION (ServerProperties)
server.port=8080
server.address= # bind to a specific NIC
server.session-timeout= # session timeout in seconds
server.context-parameters.*= # Servlet context init parameters, e.g. server.context-parameters.a=alpha
server.context-path= # the context path, defaults to '/'
server.servlet-path= # the servlet path, defaults to '/'

更多常见的应用属性请浏览这里

注意:命令行参数在app.jar的后面!

可以通过SpringApplication.setAddCommandLineProperties(false)禁用命令行配置。

Java系统属性

注意Java系统属性位置java -Dname="isea533" -jar app.jar,可以配置的属性都是一样的,优先级不同。

例如java -Dname="isea533" -jar app.jar --name="Spring!"中name值为Spring!

操作系统环境变量

配置过JAVA_HOME的应该都了解这一个。

这里需要注意的地方,有些OS可以不支持使用.这种名字,如server.port,这种情况可以使用SERVER_PORT来配置。

具体名字如何匹配,看本文后面。

RandomValuePropertySource

系统中用到随机数的地方,例如:

my.secret=${random.value}
my.number=${random.int}
my.bignumber=${random.long}
my.number.less.than.ten=${random.int(10)}
my.number.in.range=${random.int[1024,65536]}

random.int*支持value参数和,max参数,当提供max参数的时候,value就是最小值。

应用配置文件(.properties或.yml)

在配置文件中直接写:

name=Isea533
server.port=8080

.yml格式的配置文件如:

name: Isea533
server:
  port: 8080

当有前缀的情况下,使用.yml格式的配置文件更简单。关于.yml配置文件用法请看这里

注意:使用.yml时,属性名的值和冒号中间必须有空格,如name: Isea533正确,name:Isea533就是错的。

属性配置文件的位置

spring会从classpath下的/config目录或者classpath的根目录查找application.properties或application.yml。

/config优先于classpath根目录

@PropertySource

这个注解可以指定具体的属性配置文件,优先级比较低。

SpringApplication.setDefaultProperties

例如:

SpringApplication application = new SpringApplication(Application.class);
Map<String, Object> defaultMap = new HashMap<String, Object>();
defaultMap.put("name", "Isea-Blog");
//还可以是Properties对象
application.setDefaultProperties(defaultMap);
application.run(args);

应用(使用)属性

@Value(“${xxx}”)

这种方式是最简单的,通过@Value注解可以将属性值注入进来。

@ConfigurationProperties

Spring Boot 可以方便的将属性注入到一个配置对象中。例如:

my.name=Isea533
my.port=8080
my.servers[0]=dev.bar.com
my.servers[1]=foo.bar.com

对应对象:

@ConfigurationProperties(prefix="my")
public class Config {
  private String name;
  private Integer port;
  private List<String> servers = new ArrayList<String>();

  public String geName(){
    return this.name;
  }

  public Integer gePort(){
    return this.port;
  }
  public List<String> getServers() {
    return this.servers;
  }
}

Spring Boot 会自动将prefix="my"前缀为my的属性注入进来。

Spring Boot 会自动转换类型,当使用List的时候需要注意在配置中对List进行初始化!

Spring Boot 还支持嵌套属性注入,例如:

name=isea533
jdbc.username=root
jdbc.password=root
...

对应的配置类:

@ConfigurationProperties
public class Config {
  private String name;
  private Jdbc jdbc;
  class Jdbc {
    private String username;
    private String password;
    //getter...
  }

  public Integer gePort(){
    return this.port;
  }
  public Jdbc getJdbc() {
    return this.jdbc;
  }
}

jdbc开头的属性都会注入到Jdbc对象中。

在@Bean方法上使用@ConfigurationProperties

例如:

@ConfigurationProperties(prefix = "foo")
@Bean
public FooComponent fooComponent() {
  ...
}

Spring Boot 会将foo开头的属性按照名字匹配注入到FooComponent对象中。

属性占位符

例如:

app.name=MyApp
app.description=${app.name} is a Spring Boot application

可以在配置文件中引用前面配置过的属性(优先级前面配置过的这里都能用)。

通过如${app.name:默认名称}方法还可以设置默认值,当找不到引用的属性时,会使用默认的属性。

由于${}方式会被Maven处理。如果你pom继承的spring-boot-starter-parent,Spring Boot 已经将maven-resources-plugins默认的${}方式改为了@ @方式,例如@name@。

如果你是引入的Spring Boot,你可以修改使用其他的分隔符

通过属性占位符还能缩短命令参数

例如修改web默认端口需要使用--server.port=9090方式,如果在配置中写上:

server.port=${port:8080}

那么就可以使用更短的--port=9090,当不提供该参数的时候使用默认值8080。

属性名匹配规则

例如有如下配置对象:

@Component
@ConfigurationProperties(prefix="person")
public class ConnectionSettings {

  private String firstName;

}

firstName可以使用的属性名如下:

  1. person.firstName,标准的驼峰式命名
  2. person.first-name,虚线(-)分割方式,推荐在.properties和.yml配置文件中使用
  3. PERSON_FIRST_NAME,大写下划线形式,建议在系统环境变量中使用

属性验证

可以使用JSR-303注解进行验证,例如:

@Component
@ConfigurationProperties(prefix="connection")
public class ConnectionSettings {

  @NotNull
  private InetAddress remoteAddress;

  // ... getters and setters

}

最后

以上是Spring Boot 属性配置和使用的内容,有些不全面的地方或者读者有更多疑问,可以查看Spring Boot完整文档 或 Externalized Configuration。希望对大家的学习有所帮助,也希望大家多多支持。


# Spring  # Boot  # 属性配置  # 配置属性文件  # Spring中利用配置文件和@value注入属性值代码详解  # springboot如何读取配置文件(application.yml)中的属性值  # 详解Spring Boot 配置加载顺序及属性加载顺序  # 深入理解Spring Boot属性配置文件  # Spring boot将配置属性注入到bean类中  # Spring boot工具类静态属性注入及多环境配置详解  # Spring中属性文件properties的读取与使用详解  # Spring中属性注入详解  # Spring中属性注入的几种方式以及复杂属性的注入详解  # Spring事务传播属性和隔离级别详细介绍  # Spring实战之设置普通属性值的方法示例  # 配置文件  # 可以使用  # 命令行  # 还可以  # 象中  # 可以通过  # 不带  # 需要注意  # 默认值  # 操作系统  # 这一  # 如果你  # 随机数  # 你是  # 你可以  # 还能  # 找不到  # 很多人  # 下划线  # 其他的 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 如何用腾讯建站主机快速创建免费网站?  微信推文制作网站有哪些,怎么做微信推文,急?  如何在不使用负向后查找的情况下匹配特定条件前的换行符  如何在 React 中条件性地遍历数组并渲染元素  Laravel如何生成URL和重定向?(路由助手函数)  如何在企业微信快速生成手机电脑官网?  百度输入法ai面板怎么关 百度输入法ai面板隐藏技巧  如何快速搭建FTP站点实现文件共享?  INTERNET浏览器怎样恢复关闭标签页_INTERNET浏览器标签恢复快捷键与方法【指南】  如何快速生成橙子建站落地页链接?  如何用虚拟主机快速搭建网站?详细步骤解析  个人网站制作流程图片大全,个人网站如何注销?  如何用wdcp快速搭建高效网站?  手机网站制作平台,手机靓号代理商怎么制作属于自己的手机靓号网站?  Laravel怎么配置不同环境的数据库_Laravel本地测试与生产环境动态切换【方法】  Laravel DB事务怎么使用_Laravel数据库事务回滚操作  Laravel事件和监听器如何实现_Laravel Events & Listeners解耦应用的实战教程  Linux后台任务运行方法_nohup与&使用技巧【技巧】  如何在自有机房高效搭建专业网站?  北京网站制作费用多少,建立一个公司网站的费用.有哪些部分,分别要多少钱?  Laravel中Service Container是做什么的_Laravel服务容器与依赖注入核心概念解析  Gemini怎么用新功能实时问答_Gemini实时问答使用【步骤】  香港服务器租用每月最低只需15元?  Laravel项目结构怎么组织_大型Laravel应用的最佳目录结构实践  高端建站三要素:定制模板、企业官网与响应式设计优化  如何为不同团队 ID 动态生成多个非值班状态按钮  如何快速上传建站程序避免常见错误?  Laravel如何实现一对一模型关联?(Eloquent示例)  Laravel怎么配置.env环境变量_Laravel生产环境敏感数据保护与读取【方法】  新三国志曹操传主线渭水交兵攻略  微信小程序 HTTPS报错整理常见问题及解决方案  Win11怎么修改DNS服务器 Win11设置DNS加速网络【指南】  Laravel中DTO是什么概念_在Laravel项目中使用数据传输对象(DTO)  广州网站制作公司哪家好一点,广州欧莱雅百库网络科技有限公司官网?  Laravel distinct去重查询_Laravel Eloquent去重方法  VIVO手机上del键无效OnKeyListener不响应的原因及解决方法  Laravel的契約(Contracts)是什么_深入理解Laravel Contracts与依赖倒置  宙斯浏览器怎么屏蔽图片浏览 节省手机流量使用设置方法  Android GridView 滑动条设置一直显示状态(推荐)  北京企业网站设计制作公司,北京铁路集团官方网站?  如何用AI一键生成爆款短视频文案?小红书AI文案写作指令【教程】  实例解析Array和String方法  Laravel如何部署到服务器_线上部署Laravel项目的完整流程与步骤  中山网站推广排名,中山信息港登录入口?  JavaScript模板引擎Template.js使用详解  潮流网站制作头像软件下载,适合母子的网名有哪些?  Laravel如何连接多个数据库_Laravel多数据库连接配置与切换教程  Windows家庭版如何开启组策略(gpedit.msc)?(安装方法)  PHP怎么接收前端传的文件路径_处理文件路径参数接收方法【汇总】  悟空浏览器如何设置小说背景色_悟空浏览器背景色设置【方法】