ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
| この記事の要点 |
|---|
|
Model(推奨)
メソッドの引数で Model を受け取り、属性を追加。戻り値は View 名(String):
@Controller
public class UserController {
@GetMapping("/users")
public String list(Model model) {
List users = userService.findAll();
model.addAttribute("users", users);
model.addAttribute("title", "ユーザー一覧");
return "users/list"; // ← View 名 (例: users/list.jsp)
}
@GetMapping("/users/{id}")
public String show(@PathVariable Long id, Model model) {
User user = userService.findById(id);
model.addAttribute("user", user);
return "users/detail";
}
}
JSP / Thymeleaf 側
${title}
- ${user.name}
タイトル
- 名前
ModelAndView
モデルと View を 1 つのオブジェクトに包んで返す:
@Controller
public class UserController {
@GetMapping("/users")
public ModelAndView list() {
ModelAndView mav = new ModelAndView("users/list");
mav.addObject("users", userService.findAll());
mav.addObject("title", "ユーザー一覧");
return mav;
}
@GetMapping("/users/{id}")
public ModelAndView show(@PathVariable Long id) {
ModelAndView mav = new ModelAndView();
mav.setViewName("users/detail");
mav.addObject("user", userService.findById(id));
return mav;
}
}
比較
| 項目 | Model | ModelAndView |
|---|---|---|
| View 名 | 戻り値の String | オブジェクトに含む |
| 属性追加 | model.addAttribute(...) | mav.addObject(...) |
| 記述量 | 少ない | 多い |
| 条件で View 変更 | String を分岐 | setViewName(...) |
| Spring 推奨度 | 推奨 | 後方互換用 |
条件分岐の場合の書き方比較
// Model 版
@GetMapping("/users/{id}")
public String show(@PathVariable Long id, Model model) {
Optional user = userService.findByIdOptional(id);
if (user.isPresent()) {
model.addAttribute("user", user.get());
return "users/detail";
} else {
model.addAttribute("error", "User not found");
return "errors/404";
}
}
// ModelAndView 版
@GetMapping("/users/{id}")
public ModelAndView show(@PathVariable Long id) {
Optional user = userService.findByIdOptional(id);
ModelAndView mav = new ModelAndView();
if (user.isPresent()) {
mav.setViewName("users/detail");
mav.addObject("user", user.get());
} else {
mav.setViewName("errors/404");
mav.addObject("error", "User not found");
}
return mav;
}
@ModelAttribute の併用
共通のモデル属性を定義したい場合:
@Controller
public class UserController {
// すべてのメソッドのモデルに追加される
@ModelAttribute("currentUser")
public User currentUser(HttpSession session) {
return (User) session.getAttribute("user");
}
@ModelAttribute("appName")
public String appName() {
return "My App";
}
@GetMapping("/profile")
public String profile(Model model) {
// currentUser, appName はすでにモデルに追加されている
return "profile";
}
}
RedirectAttributes(リダイレクト時)
@PostMapping("/users")
public String create(@ModelAttribute User user, RedirectAttributes redirectAttributes) {
userService.create(user);
redirectAttributes.addFlashAttribute("message", "登録しました");
return "redirect:/users";
// → /users にリダイレクト、Flash 属性は次のリクエストで利用可能
}
@GetMapping("/users")
public String list(Model model, @ModelAttribute("message") String message) {
// リダイレクト後の最初の表示で message が利用可能
return "users/list";
}
@RestController なら両方不要
// View を返さず JSON を返す場合
@RestController
@RequestMapping("/api/users")
public class UserApiController {
@GetMapping
public List list() {
return userService.findAll();
// ← Jackson が自動で JSON 化
}
}
Map で簡略化
// 簡単なケースなら Map を直接返す
@GetMapping("/users/{id}")
public String show(@PathVariable Long id, Map model) {
model.put("user", userService.findById(id));
return "users/detail";
}
// または Model に対して直接 put しているのと同等
使い分けのまとめ
- 新規開発:
Model + Stringを使う - 条件で View 名が大きく変わる: ModelAndView も読みやすい場合あり
- JSON API:
@RestControllerでオブジェクト直接返却 - レガシーコード: ModelAndView をそのまま保守
関連記事
ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
子ページ
子ページはありません
同階層のページ
- インストール(eclipseプラグイン)
- クイックスタート
- プロジェクトの作成
- Spring Bootプロジェクトの作成
- Spring Bootプロジェクトの実行
- Spring BootでHello World!
- アノテーション一覧
- DB接続設定からエンティティおよびリポジトリの作成、値の取得まで(JPA編)
- DB接続設定や値の取得(JdbcTemplate編)
- ビューから値をモデルに格納しコントローラーで受け取る方法
- コントローラーにてモデルに値を格納してビューに渡す方法
- テンプレートエンジン
- ModelとModelAndViewの違い
- AOPの使用方法
- classpath: 内部ファイルの読み込み
- file: 外部ファイルの読み込み
- CSVファイルアップロード方法(Ajax)
- CSVファイルダウンロード方法(Ajax)
- Spring Bootプロジェクトのビルドと本番環境へのデプロイ方法(内部tomcat使用)
- Application.propertiesの環境依存設定の分割方法
- JPAにおけるEntityManagerの取得方法
- JPAにおけるjava.sql.Connectionの取得方法
- エラー一覧
- jarの引数を受け取る方法
- Spring BootでGmailからメール送信
- 複数のDBに接続する設定(Spring Boot & JPA編)
- ポート番号の変更
- Basic認証の実装と特定のURLに限定する方法
- Spring SecurityのBasic認証の無効化
- 独自のエラーページを定義する方法
- プロパティファイルの値やjar実行時の引数を取得する方法
人気ページ
- 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
コメントを削除してもよろしいでしょうか?