我正在加载我的属性文件,如下所示:
@Configuration
@PropertySource("classpath:app.properties")
class MyApp {
@Bean
public PropertySourcesPlaceholderConfigurer PropertySourcesPlaceholderConfigurer() {
return new PropertySourcesPlaceholderConfigurer();
}
}
在属性文件中,我有几个与数据库相关的属性:
database.dataSource.url=jdbc:postgresql://localhost:${db-port:5432}/mydb
database.dataSource.x=...
database.dataSource.y=...
database.dataSource.z=...
注意:
${db-port}
应替换为属性/环境变量db-port
或5432的值。在我的情况下,我在生成Tomcat时定义环境变量db-port
容器
所有与数据库相关的属性都归入database.
root下。这是故意的,见下文。
我想避免我必须在我的代码中枚举/硬编码所有可能的数据库相关属性。幸运的是,正在使用的数据库层(Hikari)有一个很好的功能,我可以通过所有属性java.util.Properties
。所以,我希望在database.*
下检索所有已定义的属性,然后将其转发给Hikari。
为此,我编写了以下实用程序:
@Component
public class PropertyFetcher
{
@Autowired
private ConfigurableEnvironment environment;
public Properties get(final String key) {
final Properties p = new Properties();
for (final PropertySource<?> s : environment.getPropertySources()) {
if (s instanceof EnumerablePropertySource) {
for (final String k : ((EnumerablePropertySource) s).getPropertyNames()) {
if (k.startsWith(key) && k.length() > key.length()) {
p.put(k.substring(key.length()), s.getProperty(k));
}
}
}
}
return p;
}
}
现在,在调用get("database.")
时,我拥有了属性文件中定义的所有与数据库相关的属性。大!但是,属性dataSource.url
的值现在是
jdbc:postgresql://localhost:${db-port:5432}/mydb
而不是
jdbc:postgresql://localhost:9876/mydb
因此,出于某种原因,${db-port:5432}
在通过此路线(ConfigurableEnvironment
)时未解决(但是?)。
如何解决这个问题?或者有没有更好的方法来获取某个根目录下的所有属性而无需枚举/硬编码到代码中?
请注意,在默认情况下,属性${db-port:5432}
中的database.dataSource.url=jdbc:postgresql://localhost:${db-port:5432}/mydb
已正确解析。我通过定义以下成员并记录它来测试它:
@Value("${database.dataSource.url}")
final String url; // holds jdbc:postgresql://localhost:9876/mydb
答案 0 :(得分:1)
您应该只从真实环境中读取属性值。然后,只有您将获得房产的实际或有效价值。
这需要对代码进行一些更改。
更改此行:
p.put(k.substring(key.length()), s.getProperty(k));
到此:
p.put(k.substring(key.length()), environment.getProperty(k));