カテゴリ: Spring 更新日: 2026/01/17
PR
独学でJavaを学んでいる方向け
「実務レベルに到達できるか不安」「1人だと詰まることが多い」場合は、 実践重視で学べる環境を一度確認しておくのも一つの手です。
EBAエデュケーション |学習内容・サポートを見る

SpringのThymeleafでエラー表示する方法!フォームバインドとバリデーションを丁寧に解説

画面へのエラー表示:Thymeleaf の th:field とエラー強調表現
画面へのエラー表示:Thymeleaf の th:field とエラー強調表現

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

生徒

「Springのバリデーションで入力エラーが出たとき、画面にどうやって表示すればいいんですか?」

先生

「それにはThymeleafのth:fieldth:errorsを使いますよ。エラーの強調もBootstrapと組み合わせれば簡単です。」

生徒

「じゃあ、エラーが出た項目だけ赤くして、メッセージも出せるってことですか?」

先生

「その通りです。基本から順番に見ていきましょう!」

1. Springのフォームバインドとバリデーションの基本

1. Springのフォームバインドとバリデーションの基本
1. Springのフォームバインドとバリデーションの基本

Spring MVCでは、HTMLフォームからの入力値をJavaのオブジェクトにバインドできます。そして、JSR-303のバリデーションを組み合わせることで、入力チェックも自動で行えます。

まずはフォームクラスにバリデーションアノテーションを追加しましょう。


public class UserForm {

    @NotBlank(message = "ユーザー名を入力してください")
    private String username;

    @Email(message = "メールアドレスの形式が正しくありません")
    private String email;

    // getter / setter
}

このようにすることで、入力が空だったり形式が間違っていた場合に、エラーが発生します。

2. コントローラーでエラー処理を受け取る

2. コントローラーでエラー処理を受け取る
2. コントローラーでエラー処理を受け取る

コントローラーでは、@ValidatedBindingResultを使って、バリデーション結果を受け取ります。


@PostMapping("/register")
public String register(@ModelAttribute("form") @Validated UserForm form, BindingResult result) {
    if (result.hasErrors()) {
        return "form";
    }
    return "success";
}

エラーがある場合は再度フォーム画面に戻し、エラーメッセージを表示します。

PR

将来を見据えて、+αのスキルを身につけたい方へ

JavaやLinuxを学んでいても、「このままで市場価値は上がるのか」 「キャリアの選択肢を広げたい」と感じる方は少なくありません。

AIを学ぶならアイデミープレミアム

3. Thymeleafでのエラー表示:th:fieldとth:errors

3. Thymeleafでのエラー表示:th:fieldとth:errors
3. Thymeleafでのエラー表示:th:fieldとth:errors

Thymeleafでは、Springのフォームオブジェクトと連携して、フィールドごとのエラー表示が可能です。フォーム入力欄にはth:fieldを使います。


<form th:action="@{/register}" th:object="${form}" method="post">
    <div class="mb-3">
        <label for="username" class="form-label">ユーザー名</label>
        <input type="text" th:field="*{username}" class="form-control" />
        <div th:if="${#fields.hasErrors('username')}" th:errors="*{username}" class="text-danger"></div>
    </div>

    <div class="mb-3">
        <label for="email" class="form-label">メールアドレス</label>
        <input type="email" th:field="*{email}" class="form-control" />
        <div th:if="${#fields.hasErrors('email')}" th:errors="*{email}" class="text-danger"></div>
    </div>

    <button type="submit" class="btn btn-primary">登録</button>
</form>

th:fieldは、Springのバインド情報に従ってnameid属性も自動設定してくれる便利な属性です。

4. エラーのある入力欄を強調表示する

4. エラーのある入力欄を強調表示する
4. エラーのある入力欄を強調表示する

エラーがある項目を視覚的にわかりやすくするためには、Bootstrapのis-invalidクラスを使います。


<input type="text" 
       th:field="*{username}" 
       th:classappend="${#fields.hasErrors('username')} ? ' is-invalid'" 
       class="form-control" />

th:classappendを使えば、条件に応じてクラスを追加できるため、エラーがあるときだけis-invalidが付与されます。

5. th:errorsでメッセージを表示する方法

5. <code>th:errors</code>でメッセージを表示する方法
5. th:errorsでメッセージを表示する方法

th:errorsは、フィールドごとに発生したエラーメッセージを表示するための属性です。1つのフィールドに複数の制約をつけている場合でも、自動ですべて表示されます。


<div th:errors="*{email}" class="text-danger"></div>

この要素は、エラーがあるときだけ表示され、なければ出力されません。条件分岐を書かなくても済むので便利です。

6. 全体のエラー表示:フォームレベルのバリデーション

6. 全体のエラー表示:フォームレベルのバリデーション
6. 全体のエラー表示:フォームレベルのバリデーション

フォーム全体に関するエラー(例:メールアドレスと確認用アドレスが一致しないなど)を表示したい場合は、globalErrorを使います。


<div th:if="${#fields.hasGlobalErrors()}" class="alert alert-danger">
    <ul>
        <li th:each="err : ${#fields.globalErrors()}" th:text="${err}"></li>
    </ul>
</div>

このようにすることで、入力フィールドに紐づかないエラーもユーザーに伝えることができます。

7. バリデーションエラー表示に関する注意点とコツ

7. バリデーションエラー表示に関する注意点とコツ
7. バリデーションエラー表示に関する注意点とコツ

画面にエラーを表示する際に注意すべきポイントを紹介します。

  • 入力欄の下にエラーを表示すると、ユーザーがすぐに気づきやすくなります
  • 赤色の強調やアイコンを組み合わせると、視覚的な注意喚起になります
  • プレースホルダーで補足説明を書いても、エラーの補助にはなります

ユーザビリティとセキュリティの両面で、エラーメッセージはとても大切な要素です。SpringとThymeleafを使えば、バリデーションエラーの表示は柔軟かつ簡単に実現できます。

関連記事:
カテゴリの一覧へ
新着記事
PR

JavaやLinuxの検証環境に
低コストで使えるVPS

JavaのEnumクラスの使い方を完全ガイド!初心者でもわかるjava.lang入門
JSPのコメントの書き方!HTMLコメントとの違いもわかりやすく解説
JSPとServletの違いとは?役割分担と連携の基本を初心者向けに説明
Springでバルク更新・一括挿入を高速に!flush・clearの使い方と最適化のベストプラクティス
PR 未経験からITエンジニアを目指す方へ

Javaを学んでいるけど、「このまま未経験で就職できるか不安」という20代向け。 学歴不問・無料サポートの就職支援という選択肢があります。

Tamesy |無料で面談予約
人気記事
No.1
Java&Spring記事人気No1
JavaのIntegerクラスの使い方を完全ガイド!初心者でもわかる整数操作
No.2
Java&Spring記事人気No2
Javaのラムダ式で配列を扱う!Arrays.streamの基本と注意点を初心者向けに解説
No.3
Java&Spring記事人気No3
Spring BootとJavaの互換性一覧!3.5/3.4/3.3はJava 21・17に対応してる?
No.4
Java&Spring記事人気No4
JavaのRuntimeExceptionを完全解説!初心者でもわかるjava.langパッケージの基礎
No.5
Java&Spring記事人気No5
Spring BootのJakarta移行ガイド!初心者向けjavax→jakarta変更ポイント徹底解説
No.6
Java&Spring記事人気No6
Springの@Serviceアノテーションの使い方を徹底解説!初心者でもわかるSpring フレームワーク入門
No.7
Java&Spring記事人気No7
JavaのHttpSessionを徹底解説!初心者でもわかるセッション管理の基本
No.8
Java&Spring記事人気No8
Springの@Componentアノテーションの使い方を徹底解説!初心者でもわかるSpring Boot入門
PR

ローカルPCに依存しない開発環境という選択肢

Java・Linuxの検証や学習環境を、クラウド上ですぐに用意できます。

Java入門

Javaの基礎を体系的に学びたい場合は、文法だけでなく 「なぜそう書くのか」まで丁寧に解説されているため、 初心者でも理解しやすい定番の1冊です。

スッキリわかるJava入門 第4版

※ 紙の書籍・電子書籍どちらでも購入できます

Java実践

ジェネリクス、enum、シールクラスなどの型設計から、 関数型プログラミング(ラムダ式・Stream API)、 JVM制御やリフレクション、外部ライブラリの活用までを扱っており、 「Javaを使えるレベル」へ進むための内容が網羅されています。

スッキリわかるJava入門 実践編 第4版

※ 紙の書籍・電子書籍どちらでも購入できます

Spring入門

Spring Frameworkの全体像から、 Webアプリ開発で必要となる主要機能までを 体系的に解説している定番の入門書です。

Spring徹底入門 第2版 Spring FrameworkによるJavaアプリケーション開発

※ 紙の書籍・電子書籍どちらでも購入できます

PR 実務経験のあるエンジニア向け

Javaなどの実務経験があり、次のキャリアを検討している方向け。 IT・ゲーム業界に特化した転職支援サービスという選択肢もあります。

転職ボックス |IT・ゲーム業界専門