7

我有一个带有属性映射的 YAML 配置文件:

properties:
  a.b.c: 1

Boot 会将其解析为:

{a:{b:{c:1}}}

但是,我想要的是:

{'a.b.c': 1}

有没有办法把它哄到“通过”键模式?引用密钥似乎没有帮助。


更新

下面的实际例子。

爪哇

import static com.google.common.collect.Maps.newLinkedHashMap;

import java.util.Map;
import javax.annotation.PostConstruct;

import lombok.Data;
import lombok.val;

import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.context.annotation.Configuration;

@Data
@Configuration
@ConfigurationProperties("hadoop")
public class HadoopProperties {

   private Map<Object, Object> properties = newLinkedHashMap();

}

YAML

application.yml

hadoop:
   properties:
      fs.defaultFS: hdfs://localhost:8020
      mapred.job.tracker: localhost:8021

结果

调用toString()生成的对象:

HadoopProperties(properties={fs={defaultFS=hdfs://localhost:8020}, mapred={job={tracker=localhost:8021}}})

4

2 回答 2

3

我懂了。这是因为您绑定到一个非常通用的对象,所以 Spring Boot 认为您的句点分隔符是映射键取消引用。如果绑定到 Map 或 Properties 会发生什么?

于 2014-04-29T18:24:09.863 回答
1

你可以使用如下

hadoop:
   properties:
      "[fs.defaultFS]" : hdfs://localhost:8020
      "[mapred.job.tracker]": localhost:8021

参考 -链接

于 2021-05-06T20:09:45.657 回答