ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
| この記事の要点 |
|
logic:messagesPresent タグとは
Struts 1 の は、リクエスト/セッションスコープに ActionMessages または ActionErrors が登録されているかどうかを判定し、存在する場合のみタグボディを評価する条件分岐タグです。バリデーションエラーやフラッシュメッセージを表示するときに使います。
基本的な使い方
<%@ taglib uri="http://struts.apache.org/tags-html" prefix="html" %>
<%@ taglib uri="http://struts.apache.org/tags-logic" prefix="logic" %>
<%@ taglib uri="http://struts.apache.org/tags-bean" prefix="bean" %>
<%-- エラーがあるときだけブロックを表示 --%>
属性一覧
| 属性 | 必須 | 意味 |
|---|---|---|
name | 任意 | 判定するメッセージのスコープ属性名。省略時は Globals.ERROR_KEY |
property | 任意 | 特定フィールドのエラーだけ判定 |
message | 任意 | true なら Globals.MESSAGE_KEY (ActionMessages) を見る。デフォルトは ERROR_KEY |
Action 側のコード
JSP 側で messagesPresent を使うには、Action 側で ActionErrors / ActionMessages を保存しておく必要があります:
public class LoginAction extends Action {
public ActionForward execute(ActionMapping mapping, ActionForm form,
HttpServletRequest req, HttpServletResponse res) {
LoginForm lf = (LoginForm) form;
// バリデーション
ActionErrors errors = new ActionErrors();
if (lf.getUserId() == null || lf.getUserId().isEmpty()) {
errors.add("userId",
new ActionMessage("error.required", "ユーザー ID"));
}
if (lf.getPassword() == null || lf.getPassword().length() < 8) {
errors.add("password",
new ActionMessage("error.length", "パスワード", "8"));
}
if (!errors.isEmpty()) {
saveErrors(req, errors); // ★ ERROR_KEY に保存
return mapping.getInputForward();
}
// 成功メッセージ
ActionMessages msgs = new ActionMessages();
msgs.add(ActionMessages.GLOBAL_MESSAGE,
new ActionMessage("login.success", lf.getUserId()));
saveMessages(req, msgs); // ★ MESSAGE_KEY に保存
return mapping.findForward("success");
}
}
property でフィールド指定
特定の入力フィールドにエラーがある場合のみ表示したいとき:
- ユーザー ID
-
- パスワード
-
message="true" で ActionMessages を判定
エラーではなく成功メッセージ等を扱うとき:
<%-- 成功メッセージ表示 (MESSAGE_KEY) --%>
<%-- エラーメッセージ表示 (デフォルト = ERROR_KEY) --%>
messagesNotPresent — エラーなしの分岐
逆の条件を書く場合は :
エラーがあります。修正してください。
入力内容を確認の上、送信ボタンを押してください。
html:messagesPresent との違い
Struts 1.3 系で似た名前のタグがありますが、役割は同じです:
| タグ | TLD | 動作 |
|---|---|---|
| struts-logic | 古典的な書き方 | |
| struts-html | 1.3 で html タグライブラリへ移動 |
機能差はないので、プロジェクトの慣習に合わせれば OK。
Spring MVC への移行
Spring MVC では BindingResult + を使います:
@Controller
public class LoginController {
@PostMapping("/login")
public String login(@Valid @ModelAttribute LoginForm form,
BindingResult br) {
if (br.hasErrors()) {
return "login";
}
return "redirect:/home";
}
}<%@ taglib prefix="form" uri="http://www.springframework.org/tags/form" %>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<%-- 全体エラー --%>
<%-- フィールド別エラー --%>
<%-- フラッシュメッセージ (RedirectAttributes) --%>
${flashMessage}
JSTL + EL で書く
Struts タグを使わず JSTL だけで書く場合:
FAQ
Q: messagesPresent はネスト可能?
A: 可能。ただし分岐を深くしすぎると保守性が落ちるため、フィールド別エラー表示はループで書く方が無難。
Q: メッセージリソースの場所は?
A: struts-config.xml の で指定。MessageResources.properties に error.required={0} は必須です のように書く。
Q: エラーメッセージのスタイルを変えたい ページの作成
親となるページを選択してください。
子ページはありません 同階層のページはありません
A: messagesPresent のボディに 関連項目
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
人気ページ
- 1 Eclipseで「サーバーに追加または除去できるリソースがありません。」の原因と対処法
- 2 tomcat の起動 / 停止ログと catalina.log・catalina.out の違い
- 3 JavaScript base URL 取得方法|window.location.origin と SSR/Node.js 対応
- 4 YouTube Data API v3 エラー一覧|403/400/404 の主要原因と切り分け
- 5 Spring Frameworkのアノテーション一覧
- 6 Laravel エラー一覧|500/Blade/DB 接続/ルーティングの代表エラー
- 7 3Dグラフィックスとは|モデリング/レンダリング/主要ソフトウェア (Blender / Maya)
- 8 【Spring】@Valueアノテーションとは
- 9 CATALINA_HOME の確認方法 (Linux / Mac)
- 10 【Spring】@Autowiredアノテーションとは
最近更新/作成されたページ
- Laravel キャッシュクリア完全ガイド(cache:clear / config:clear / 2026-05-18 07:42:07
- プロジェクトの作成と削除 2026-05-18 07:42:07
- インストール直後にNetbeansが反応しない 2026-05-18 07:42:07
- 動画やチャンネルの検索 2026-05-18 07:42:07
- APIキー取得方法 2026-05-18 07:42:07
- チャンネル情報の取得 2026-05-18 07:42:07
- API 入門 — Web API(REST / GraphQL / gRPC / 2026-05-18 07:42:07
- インストール(eclipseプラグイン) 2026-05-18 07:42:07
- Laravel「Dotenv values containing spaces must be surrounded 2026-05-18 07:42:07
- エラー一覧 2026-05-18 07:42:07
- curl: (51) SSL: certificate subject name '~' does not match 2026-05-18 07:42:07
- インストール方法(Windows版) 2026-05-18 07:42:07
- JSONから配列に変換 2026-05-18 07:42:07
- 処理を一定時間待つ 2026-05-18 07:42:07
- A non well formed numeric value encountered 2026-05-18 07:42:07
コメントを削除してもよろしいでしょうか?
掲示板