ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
| この記事の要点 |
|---|
|
@Controller の基本
@Controller
@RequestMapping("/users")
public class UserController {
private final UserService userService;
public UserController(UserService userService) {
this.userService = userService;
}
@GetMapping
public String list(Model model) {
List users = userService.findAll();
model.addAttribute("users", users);
return "users/list"; // ← View 名 (users/list.html or .jsp)
}
@GetMapping("/{id}")
public String show(@PathVariable Long id, Model model) {
User user = userService.findById(id);
model.addAttribute("user", user);
return "users/show";
}
@GetMapping("/create")
public String createForm(Model model) {
model.addAttribute("user", new UserCreateForm());
return "users/create";
}
@PostMapping
public String create(@ModelAttribute @Valid UserCreateForm form, BindingResult result) {
if (result.hasErrors()) {
return "users/create"; // バリデーション失敗
}
User user = userService.createUser(form.getName(), form.getEmail());
return "redirect:/users/" + user.getId();
}
}
@Controller vs @RestController
| 項目 | @Controller | @RestController |
|---|---|---|
| 用途 | HTML / JSP View 返却 | JSON / XML API |
| 戻り値 | View 名 (String) | POJO → JSON 自動変換 |
| @ResponseBody | 個別メソッドに付ける | クラス全体に暗黙適用 |
| 典型例 | サーバサイドレンダリング | SPA バックエンド / 外部 API |
View 名の解決
@GetMapping("/users/{id}")
public String show(@PathVariable Long id, Model model) {
model.addAttribute("user", userService.findById(id));
return "users/show";
// ↓ ViewResolver が以下を探す
// - templates/users/show.html (Thymeleaf)
// - WEB-INF/jsp/users/show.jsp (JSP)
// - 等
}
// プレフィックス
return "redirect:/users"; // → 302 redirect
return "forward:/api/internal"; // → 内部 forward (同 request)
return "users/show"; // → 通常 view 解決
Model / ModelAndView
// Model 引数で受け取る (推奨)
@GetMapping("/users/{id}")
public String show(@PathVariable Long id, Model model) {
model.addAttribute("user", userService.findById(id));
model.addAttribute("title", "ユーザー詳細");
return "users/show";
}
// ModelAndView 返却
@GetMapping("/users/{id}")
public ModelAndView showMav(@PathVariable Long id) {
ModelAndView mav = new ModelAndView("users/show");
mav.addObject("user", userService.findById(id));
return mav;
}
// Map 引数 (簡略形)
@GetMapping("/users/{id}")
public String showMap(@PathVariable Long id, Map model) {
model.put("user", userService.findById(id));
return "users/show";
}
フォーム受け取り
// フォーム DTO
public class UserCreateForm {
@NotBlank(message = "名前は必須です")
@Size(max = 100)
private String name;
@NotBlank
@Email
private String email;
// getter/setter
}
// 表示
@GetMapping("/users/create")
public String createForm(Model model) {
model.addAttribute("form", new UserCreateForm());
return "users/create";
}
// 受信 + バリデーション
@PostMapping("/users")
public String create(@ModelAttribute("form") @Valid UserCreateForm form,
BindingResult result,
RedirectAttributes redirect) {
if (result.hasErrors()) {
return "users/create"; // フォームに戻る (エラー表示)
}
User user = userService.createUser(form.getName(), form.getEmail());
redirect.addFlashAttribute("message", "ユーザーを作成しました");
return "redirect:/users/" + user.getId();
}
HTML テンプレート (Thymeleaf)
タイトル
名前
メール
編集
例外ハンドリング
@Controller
public class UserController {
@ExceptionHandler(EntityNotFoundException.class)
public String handleNotFound(EntityNotFoundException ex, Model model) {
model.addAttribute("error", ex.getMessage());
return "errors/404";
}
@ExceptionHandler(BusinessException.class)
public String handleBusiness(BusinessException ex, RedirectAttributes redirect) {
redirect.addFlashAttribute("error", ex.getMessage());
return "redirect:/users";
}
}
// グローバル
@ControllerAdvice
public class GlobalExceptionHandler {
@ExceptionHandler(Exception.class)
public String handleAll(Exception ex, Model model) {
model.addAttribute("error", "システムエラー");
return "errors/500";
}
}
関連記事
ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子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
コメントを削除してもよろしいでしょうか?