ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
| この記事の要点 |
|---|
|
基本的な使い方
@RestController
@RequestMapping("/api/users") // ← クラスレベル:共通プレフィックス
public class UserController {
@RequestMapping(method = RequestMethod.GET)
public List list() { ... } // GET /api/users
@RequestMapping(value = "/{id}", method = RequestMethod.GET)
public User get(@PathVariable Long id) { ... } // GET /api/users/123
@RequestMapping(method = RequestMethod.POST)
public User create(@RequestBody User user) { ... } // POST /api/users
}
HTTP メソッド別ショートカット(推奨)
| HTTP メソッド | ショートカット | @RequestMapping 等価 |
|---|---|---|
| GET | @GetMapping | @RequestMapping(method = RequestMethod.GET) |
| POST | @PostMapping | @RequestMapping(method = RequestMethod.POST) |
| PUT | @PutMapping | @RequestMapping(method = RequestMethod.PUT) |
| DELETE | @DeleteMapping | @RequestMapping(method = RequestMethod.DELETE) |
| PATCH | @PatchMapping | @RequestMapping(method = RequestMethod.PATCH) |
@RestController
@RequestMapping("/api/users")
public class UserController {
@GetMapping public List list() { ... }
@GetMapping("/{id}") public User get(@PathVariable Long id) { ... }
@PostMapping public User create(@RequestBody User user) { ... }
@PutMapping("/{id}") public User update(@PathVariable Long id, @RequestBody User u) { ... }
@DeleteMapping("/{id}") public void delete(@PathVariable Long id) { ... }
}
主要な属性
| 属性 | 用途 |
|---|---|
value / path | URL パス(複数指定可) |
method | HTTP メソッド(複数指定可) |
params | クエリパラメータ条件 |
headers | HTTP ヘッダ条件 |
consumes | 受け付ける Content-Type |
produces | 返す Content-Type |
マッチング条件で絞り込む
① クエリパラメータ条件
// type=admin が必須
@GetMapping(value = "/users", params = "type=admin")
public List listAdmins() { ... }
// type が指定されていない
@GetMapping(value = "/users", params = "!type")
public List listAll() { ... }
// 複数条件
@GetMapping(value = "/users", params = {"status=active", "role"})
public List listActiveByRole(...) { ... }
② ヘッダ条件
@GetMapping(value = "/data", headers = "X-API-Version=2")
public DataV2 getV2() { ... }
@PostMapping(value = "/upload", headers = "Content-Type=multipart/form-data")
public Response upload(...) { ... }
③ Content-Type / Accept ヘッダ(consumes / produces)
// JSON のみ受け付ける
@PostMapping(value = "/users", consumes = "application/json")
public User create(@RequestBody User user) { ... }
// 複数の Content-Type 対応
@PostMapping(consumes = {"application/json", "application/xml"})
public User create(@RequestBody User user) { ... }
// JSON でレスポンスを返す(クライアント Accept ヘッダで判定)
@GetMapping(value = "/{id}", produces = "application/json")
public User get(...) { ... }
// CSV を返す
@GetMapping(value = "/export", produces = "text/csv")
public String exportCsv() { ... }
複数 URL を 1 つのメソッドに
@GetMapping({"/users", "/users/"}) // 末尾スラッシュあり・なし両対応
public List list() { ... }
// クラスとメソッド両方で複数
@RequestMapping({"/api/users", "/api/v2/users"})
public class UserController {
@GetMapping
public List list() { ... }
// → /api/users, /api/v2/users 両方でアクセス可
}
パスパターン(ワイルドカード)
// ?: 1 文字ワイルドカード
@GetMapping("/items/?")
public Item get(@PathVariable String id) { ... }
// *: 1 セグメントワイルドカード
@GetMapping("/items/*")
public List- list() { ... }
// **: 0 以上のセグメント
@GetMapping("/files/**")
public Resource serve(HttpServletRequest req) {
String path = req.getRequestURI().substring("/files/".length());
// ファイル配信
}
// 正規表現
@GetMapping("/items/{id:[0-9]+}")
public Item get(@PathVariable Long id) { ... }
注意: @RequestMapping と @RestController の組み合わせ
// 良い例
@RestController
@RequestMapping("/api/users")
public class UserController { ... }
// 古い例(今は @RestController + @RequestMapping のほうが明示的)
@Controller
@ResponseBody
@RequestMapping("/api/users")
public class UserController { ... }
関連記事
ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子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アノテーションとは
最近更新/作成されたページ
- IPv6とは|128bitアドレス・コロン16進表記/::省略・リンクローカル・SLAAC・デュアルスタック NEW 2026-06-22 12:34:44
- VPNとは|暗号トンネル・サイト間/リモートアクセス・IPsec/SSL-VPN/WireGuardを解説 NEW 2026-06-22 12:19:10
- MAC アドレスフィルタリングの仕組みと限界 | ネットワーク入門 NEW 2026-06-22 12:19:10
- WebSocket とは 全二重リアルタイム通信 ws/wss | ネットワーク入門 NEW 2026-06-22 12:17:25
- Web通信プロトコル入門 HTTP/2・HTTP/3・WebSocket・gRPC・WebRTC | ネットワーク入門 NEW 2026-06-22 12:17:25
- HTTP/3 (QUIC) とは UDP ベースの低遅延 Web 通信 | ネットワーク入門 NEW 2026-06-22 12:17:25
- WebRTC とは ブラウザ間 P2P の音声・映像・データ通信 | ネットワーク入門 NEW 2026-06-22 12:17:25
- gRPC とは HTTP/2 + Protocol Buffers の高速 RPC | ネットワーク入門 NEW 2026-06-22 12:17:25
- HTTP/2 とは 多重化・HPACK・バイナリフレーム | ネットワーク入門 NEW 2026-06-22 12:17:25
- iptables/nftablesとは|テーブル・チェーン・ルール例・永続化をLinux視点で解説 NEW 2026-06-22 12:17:24
- HAProxy とは frontend/backend と設定例 | ネットワーク入門 NEW 2026-06-22 12:17:24
- ファイアウォールとは|パケットフィルタ・ステートフル・DMZ・次世代FW(L4/L7)を解説 NEW 2026-06-22 12:17:24
- TLS/SSLの仕組み|ハンドシェイク・暗号スイート・前方秘匿性・証明書検証をわかりやすく解説 NEW 2026-06-22 12:17:24
- CDN とは エッジキャッシュ・TTL・Cloudflare/CloudFront | ネットワーク入門 NEW 2026-06-22 12:17:24
- 証明書と認証局(CA)とは|X.509・信頼チェーン・DV/OV/EV・失効(CRL/OCSP)を解説 NEW 2026-06-22 12:17:24
コメントを削除してもよろしいでしょうか?