1ファイルタイプ
1.1プロパティ
以前のプロパティの使用法と同じ
注:プロパティの構成優先度はymlの構成優先度よりも高くなります
1.2 yaml
1.2.1はじめに
YAMLは、「YAML Ai n't MarkupLanguage」の再帰的頭字語です(YAMLはマークアップ言語ではありません)。この言語が開発されたとき、YAMLは実際には「YetAnother MarkupLanguage」(まだマークアップ言語)を意味していました。
データ中心のプロファイルに最適
1.2.2基本構文
-
キー:値;kvの間にスペースがあります
-
大文字と小文字を区別
-
インデントを使用して階層を示す
-
インデントはタブを許可せず、スペースのみを許可します
-
同じレベルの要素が左揃えである限り、インデントされたスペースの数は重要ではありません。
-
「#」はコメントを意味します
-
文字列を引用符で囲む必要はありません。追加する場合は、文字列の内容がエスケープ/エスケープ解除
''
されることを""
意味します。- たとえば
\n
、一重引用符は文字列として出力され、二重引用符は折り返されます - 文字列が数値の場合、数値はゼロで始まり、追加する必要があります。
""
そうでない場合、Springbootは数値を8進数に解析します。
- たとえば
1.2.3、データ型
- リテラル:単一の不可分な値。日付、ブール値、文字列、数値、null
k: v
- オブジェクト:キーと値のペアのコレクション。マップ、ハッシュ、オブジェクト
行内写法: k: {
k1:v1,k2:v2,k3:v3}
#或
k:
k1: v1
k2: v2
k3: v3
- 配列:順序付けられた値のセット。配列、リスト、キュー、セット
行内写法: k: [v1,v2,v3]
#或者
k:
- v1
- v2
- v3
1.2.4。例
@Data
public class Person {
private String userName;
private Boolean boss;
private Date birth;
private Integer age;
private Pet pet;
private String[] interests;
private List<String> animal;
private Map<String, Object> score;
private Set<Double> salarys;
private Map<String, List<Pet>> allPets;
}
@Data
public class Pet {
private String name;
private Double weight;
}
# yaml表示以上对象
person:
# username: 'zhangsan \n 李四'
# 单引号会将 \n 作为 字符串 输出
username: "zhangsan \n 李四"
# 双引号会将 \n 作为 换行 输出
# 双引号不会转义,单引号会转义
boss: true
birth: 2019/12/9
age: 2
# interests: [篮球,足球]
interests:
- 篮球
- 足球
- 18
animal: [小猫,小狗]
# score:
# english: 80
# math: 90
score: {
english:80,math:90}
salarys:
- 9999.98
- 9999.99
pet:
name: 小狗
weight: 50
allPets:
sick:
- {
name: 小狗,weight: 50}
- name: 小猫
weight: 66
- name: 小花
weight: 77
health:
- {
name: 小红,weight: 99}
- {
name: 小明,weight: 88}
2構成のヒント
カスタムクラスと構成ファイルのバインディングには通常プロンプトがないため、記述しやすいように、次の依存関係を使用して構成プロンプトを表示できます。バージョン2.5.6では、パッケージ化時に依存関係が自動的に削除されています。
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-configuration-processor</artifactId>
<optional>true</optional>
</dependency>