カテゴリ: Spring 更新日: 2026/02/23

Spring Bootの@ConfigurationProperties入門!初心者でもわかる型安全バインドとバリデーション

@ConfigurationProperties 入門:型安全バインドとバリデーション
@ConfigurationProperties 入門:型安全バインドとバリデーション

先生と生徒の会話形式で理解しよう

生徒

「Spring Bootで設定ファイルの値をJavaクラスにまとめて読み込む方法ってありますか?」

先生

「Spring Bootには@ConfigurationPropertiesという便利なアノテーションがあって、設定値をクラスにバインドして管理することができます。」

生徒

「@Valueじゃなくてそっちの方がいいんですか?」

先生

「@Valueも使えますが、@ConfigurationPropertiesの方が型安全で、まとまった設定を管理しやすいですよ。では、実際の使い方を見てみましょう!」

1. ConfigurationPropertiesとは?

1. ConfigurationPropertiesとは?
1. ConfigurationPropertiesとは?

@ConfigurationPropertiesは、Spring Bootで設定ファイル(application.propertiesapplication.yml)の値をJavaクラスにマッピングするためのアノテーションです。

例えば、接続設定や認証情報、APIの設定など、複数のプロパティをひとつのクラスにまとめて管理したいときに非常に役立ちます。

@Valueのように個別に読み込むのではなく、一括でバインドできるのがポイントです。

2. 基本的な使い方

2. 基本的な使い方
2. 基本的な使い方

まずは、application.ymlに以下のような設定を書きます。


app:
  name: MySpringApp
  version: 1.0.0
  admin:
    email: admin@example.com
    enabled: true

次に、対応するJavaクラスを作成します。


@Component
@ConfigurationProperties(prefix = "app")
public class AppProperties {

    private String name;
    private String version;
    private Admin admin;

    public static class Admin {
        private String email;
        private boolean enabled;

        // getter/setter
    }

    // getter/setter
}

このように、prefixを使ってプロパティ名を指定し、対応するフィールドに自動で値がバインドされます。

3. @EnableConfigurationPropertiesの必要性

3. @EnableConfigurationPropertiesの必要性
3. @EnableConfigurationPropertiesの必要性

Spring Boot 2.2以降では、@Componentを付ければ@ConfigurationPropertiesは自動で登録されますが、明示的に使用する場合は@EnableConfigurationPropertiesを使います。

たとえば、設定専用クラスとして登録したいときは次のようにします。


@Configuration
@EnableConfigurationProperties(AppProperties.class)
public class AppConfig {
}

このようにすれば、Beanとして自動的に読み込まれ、他のクラスでも@Autowiredで利用できます。

4. @Valueとの違い

4. @Valueとの違い
4. @Valueとの違い

@Value@ConfigurationPropertiesはどちらも設定値を読み込む方法ですが、以下のような違いがあります。

  • @Value:単一の値を簡単に読み込むのに適している
  • @ConfigurationProperties:複数のプロパティをまとめて管理したいときに便利

大規模な設定やネストしたプロパティ構造では、@ConfigurationPropertiesの方が圧倒的に使いやすいです。

5. バリデーションの追加

5. バリデーションの追加
5. バリデーションの追加

@ConfigurationPropertiesでは、設定値の妥当性をチェックするためにバリデーションも行えます。

バリデーションを行うには、以下の手順を踏みます。


@Component
@ConfigurationProperties(prefix = "app")
@Validated
public class AppProperties {

    @NotBlank
    private String name;

    @Pattern(regexp = "\\d+\\.\\d+\\.\\d+")
    private String version;

    @Valid
    private Admin admin;

    public static class Admin {
        @Email
        private String email;

        private boolean enabled;

        // getter/setter
    }

    // getter/setter
}

このように、javax.validationのアノテーションを使えば、プロパティ値の形式チェックができます。

6. プロパティのリストやMapも扱える

6. プロパティのリストやMapも扱える
6. プロパティのリストやMapも扱える

@ConfigurationPropertiesでは、ListやMapなどのコレクション型の設定も扱えます。

例:


app:
  servers:
    - dev.example.com
    - test.example.com

private List<String> servers;

また、Map型を使えば、キーと値の組み合わせで設定を扱うこともできます。

7. アプリケーションからプロパティを使う方法

7. アプリケーションからプロパティを使う方法
7. アプリケーションからプロパティを使う方法

バインドされたプロパティは、通常のBeanと同じように@Autowiredして利用できます。


@RestController
public class InfoController {

    private final AppProperties appProperties;

    public InfoController(AppProperties appProperties) {
        this.appProperties = appProperties;
    }

    @GetMapping("/info")
    public String info() {
        return appProperties.getName() + " - " + appProperties.getVersion();
    }
}

このようにすれば、設定ファイルの内容を簡単にアプリケーション内で使うことができます。

8. 設定ファイルの変更と反映について

8. 設定ファイルの変更と反映について
8. 設定ファイルの変更と反映について

プロパティファイルの値を変更しても、通常のSpring Bootアプリケーションでは再起動しない限り反映されません

ただし、Spring Cloud Configなどを導入すれば、設定の動的リロードも可能になります。

初心者のうちは、まずはアプリ再起動で反映される基本的な仕組みを理解しましょう。

9. ConfigurationPropertiesでよく使うアノテーション一覧

9. ConfigurationPropertiesでよく使うアノテーション一覧
9. ConfigurationPropertiesでよく使うアノテーション一覧

設定のバリデーションや構造化のために、次のアノテーションをよく使います。

  • @NotBlank:空白禁止
  • @Email:メール形式
  • @Pattern:正規表現マッチ
  • @Min / @Max:数値範囲の指定
  • @Valid:ネストしたオブジェクトの検証
  • @Validated:クラス全体にバリデーションを有効化

これらを使いこなすことで、設定ファイルのエラーを防ぎ、より堅牢なアプリケーションを作ることができます。

Springの学習を効率化したい方へ

この記事の内容をもっと深く知るには、以下の入門書が最適です。

Spring Framework超入門をAmazonで見る
カテゴリの一覧へ
新着記事
New1
Spring
SpringDataJPAのJPAクエリメソッド「In」の使い方を完全ガイド!初心者向け解説
更新記事
New2
Spring
Spring Bootの@ConfigurationProperties入門!初心者でもわかる型安全バインドとバリデーション
新規投稿
New3
Spring
SpringDataJPAのJPAクエリメソッド「Not」の使い方を完全ガイド!初心者向け解説
更新記事
New4
Spring
SpringDataJPAのJPAクエリメソッド「Containing」の使い方を完全ガイド!初心者向け解説
更新記事
人気記事
No.1
Java&Spring記事人気No1
Spring
Spring BootとJavaの互換性一覧!3.5/3.4/3.3はJava 21・17に対応してる?
No.2
Java&Spring記事人気No2
Java
JavaのBooleanクラスの使い方を完全ガイド!初心者でもわかる真偽値の操作
No.3
Java&Spring記事人気No3
JSP
JSPの基本タグ一覧と使い方まとめ!実務で使えるタグを紹介
No.4
Java&Spring記事人気No4
Java
JavaのIOExceptionクラス徹底解説!初心者向けファイル入出力エラー対策ガイド
No.5
Java&Spring記事人気No5
Spring
SpringDataJPAのJPAクエリメソッド「EndingWith」の使い方を完全ガイド!初心者向け解説
No.6
Java&Spring記事人気No6
JSP
JSPでif文・for文を使う方法!初心者でもわかるJavaとの違いと使い方
No.7
Java&Spring記事人気No7
Spring
SpringのModelクラスとaddAttributeメソッドの使い方を完全ガイド!初心者でも安心
No.8
Java&Spring記事人気No8
Spring
SpringのBindingResultを完全ガイド!初心者でもわかる入力チェックとエラー処理