文章目录
@value
一般常用
配置:
node.name=001
代码:
@Component
public class CoreConfig {
@Value("${node.name:000}")
String nodeName;
......
}
- 通过@value 获取 “${}” 内填写配置文件对应得到key内容就可以获取对应的值
- 这个key必须存在,要不然会报错。
- 添加【:】冒号设置默认值。当读取配置文件失败后会用冒号后面的值作为当前属性值。但是需要注意数据类型。
Map 类型
配置:
maps="{"key1": "value1", "key2": "value2"}"
注意:如果Map类型的key包含非字母数字和-的字符,需要用引号括起来,否则不需要使用引号(建议都用上引号);value值,都必须要用引号括起来。
其实对应的内容就是一个标准的JSON格式
代码:
@Value("#{${maps}}")
private Map<String,String> maps;
注意:这里在原先一般用法的基础上又增加了一层 #{ }
List 类型
配置:
list=l1,l2,l3
代码:
@Value("#{'${list}'.split(',')}")
private List<String> list;
这个其实不难理解 list 和一般用法一样。再按照逗号“,”进行split操作返回的就是一个list了。
@ConfigurationProperties
通过配置 @ConfigurationProperties(prefix = “前缀”)来获取对应的配置文件内容
一般常用
假如配置文件内容如下:
eos:
wallet:
url: 127.0.0.1:8080
name: default
pass: PW5KNoYMswWzozFReBbgeXwj5c1nHr9H76WYNfKW2Vtak4fZ5abc2
那么程序代码:
-
方式一
@Configuration @ConfigurationProperties(prefix = "eos") public class ChainConfig { Wallet wallet; ... } ... public class Wallet { String url; String name; String pass; ... }
-
方式二
@Configuration
@ConfigurationProperties(prefix = "eos.wallet")
public class Wallet {
String url;
String name;
String pass;
...
}
MAP 类型
针对上面对象类型还可以改变为map对象来进行配置:
@Configuration
@ConfigurationProperties(prefix = "eos")
public class ChainConfig {
Map<String,String> wallet;
...
}
这里将 原先的Wallet 对象改变为了Map对象
List 类型
对于数组也类似:
配置文件:
eos.url[0]=123
eos.url[1]=345
eos.url[2]=456
@Configuration
@ConfigurationProperties(prefix = "eos")
public class Wallet {
List<String> url;
...
}
Environment
通过这个对象读取配置。但那是一般不常用。类似和@value很像
参考如下:
@Component
public class EosWalletConfig {
@Autowired
private Environment environment;
public String getUrl() {
return environment.getProperty("eos.wallet.url");
}
}