gpt4 book ai didi

java - 带有敏感信息的 Spring Boot 外部配置不起作用

转载 作者:行者123 更新时间:2023-12-02 03:37:53 24 4
gpt4 key购买 nike

我正在尝试将外部 yml 文件加载到我的 Spring Boot 应用程序中在我的类路径上,我有 3 个用于 dev prod 和 tls 配置文件的 yml 文件。

我打算加载一个名为“secret.yml”的外部文件来覆盖 application-{profiles}.yml 文件上的值。

此“secret.yml”文件包含敏感信息。它将被添加到 gitignore 文件中。

经过一番尝试,我发现只有当我将名称更改为application-{profiles}.yml而不是secret.yml时,spring才不会覆盖类路径中的值

我尝试添加 spring.config.name=secret 但这对我不起作用。

./mvnw -Dmaven.test.skip=true -Dspring.config.additional-location=file:./secret.yml -Dspring.config.name=secret.yml

您有解决这个问题的方法吗?

[更新]

我导出环境变量export Secret="secret.yml"然后将变量传递到我的命令行

./mvnw -Dmaven.test.skip=true -Dspring.config.additional-location=file:./secret -Dspring.config.name=secret

没有任何改变

最佳答案

如果您传递多个配置文件,请注意顺序,最后一个将按顺序覆盖前一个配置。

-Dspring.config.location=classpath:application-1.yaml,classpath:application-2.yaml .. other config

如果它们具有相同的配置,application-2.yaml 的值将被覆盖到 application-1.yaml 中。

**这将针对不同的配置进行合并。

关于java - 带有敏感信息的 Spring Boot 外部配置不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60073117/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com