ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
| この記事の要点 |
|
REST とは
REST(Representational State Transfer)は、Roy Fielding が 2000 年の博士論文で提唱した分散システムのアーキテクチャスタイルです。Web を支える HTTP プロトコルを最大限活用する設計思想で、現在の Web API の事実上の標準になっています。「REST API」「RESTful」という言葉は、この設計原則に従った API を指します。
REST の 6 つの設計原則
| 原則 | 意味 |
|---|---|
| クライアント / サーバ | 関心の分離 — UI とデータを別レイヤーに |
| ステートレス | サーバはセッション状態を持たない — 各リクエストが完結 |
| キャッシュ可能 | レスポンスはキャッシュ可否を明示 |
| 統一インターフェース | リソース / 表現 / メッセージ / HATEOAS の統一 |
| 階層化システム | プロキシ / ゲートウェイ等を間に挟める |
| コードオンデマンド(任意) | JS などのコード配布 — 必須ではない |
リソースと URI
REST ではすべてのものをリソースとして扱い、URI で識別します。動詞ではなく名詞を URI にするのが原則です。
| NG(動詞ベース) | OK(リソースベース) |
|---|---|
| /getUser?id=1 | GET /users/1 |
| /createOrder | POST /orders |
| /updateProduct?id=10 | PUT /products/10 |
| /deleteUser?id=5 | DELETE /users/5 |
HTTP メソッドと CRUD の対応
| メソッド | 用途 | CRUD | 冪等性 | セーフ |
|---|---|---|---|---|
| GET | リソース取得 | Read | ○ | ○ |
| POST | 新規作成 | Create | × | × |
| PUT | 更新(全置換) | Update | ○ | × |
| PATCH | 部分更新 | Update | △ | × |
| DELETE | 削除 | Delete | ○ | × |
冪等: 同じ操作を何度繰り返しても結果が同じ。セーフ: サーバ状態を変更しない。これらの性質は分散システムのリトライやキャッシュ設計で重要です。
ステータスコード
| コード | 意味 | 典型シーン |
|---|---|---|
| 200 OK | 成功 | GET / 一般成功 |
| 201 Created | 作成成功 | POST で新規作成完了 |
| 204 No Content | 成功(本文なし) | DELETE 成功 |
| 301 / 302 | リダイレクト | URL 変更 |
| 400 Bad Request | 不正リクエスト | パラメータ不正 |
| 401 Unauthorized | 未認証 | トークンなし |
| 403 Forbidden | 権限なし | 認証済だが権限不足 |
| 404 Not Found | 存在しない | 不正な ID |
| 409 Conflict | 競合 | 重複登録 |
| 500 Internal Server Error | サーバエラー | 例外 |
JSON でのやり取り例
# 取得
GET /users/1 HTTP/1.1
Accept: application/json
HTTP/1.1 200 OK
Content-Type: application/json
{
"id": 1,
"name": "山田太郎",
"email": "yamada@example.com"
}# 作成
POST /users HTTP/1.1
Content-Type: application/json
{ "name": "佐藤花子", "email": "sato@example.com" }
HTTP/1.1 201 Created
Location: /users/2
JAX-RS(Java EE / Jakarta EE)
Java EE / Jakarta EE における REST 実装は JAX-RS(Java API for RESTful Web Services)が標準仕様です。実装としては Jersey(リファレンス実装)や RESTEasy が代表的。
import jakarta.ws.rs.*;
import jakarta.ws.rs.core.*;
@Path("/users")
public class UserResource {
@GET
@Path("/{id}")
@Produces(MediaType.APPLICATION_JSON)
public User getUser(@PathParam("id") long id) {
return userService.find(id);
}
@POST
@Consumes(MediaType.APPLICATION_JSON)
@Produces(MediaType.APPLICATION_JSON)
public Response create(User user) {
User saved = userService.save(user);
return Response.created(URI.create("/users/" + saved.getId()))
.entity(saved)
.build();
}
@PUT
@Path("/{id}")
public User update(@PathParam("id") long id, User user) {
user.setId(id);
return userService.update(user);
}
@DELETE
@Path("/{id}")
public Response delete(@PathParam("id") long id) {
userService.delete(id);
return Response.noContent().build();
}
}
Spring Boot による実装
Spring 系では @RestController アノテーションで JAX-RS と同等のことができます。
@RestController
@RequestMapping("/users")
public class UserController {
private final UserService userService;
public UserController(UserService userService) { this.userService = userService; }
@GetMapping("/{id}")
public User getUser(@PathVariable long id) {
return userService.find(id);
}
@PostMapping
public ResponseEntity<User> create(@RequestBody User user) {
User saved = userService.save(user);
return ResponseEntity
.created(URI.create("/users/" + saved.getId()))
.body(saved);
}
@PutMapping("/{id}")
public User update(@PathVariable long id, @RequestBody User user) {
user.setId(id);
return userService.update(user);
}
@DeleteMapping("/{id}")
public ResponseEntity<Void> delete(@PathVariable long id) {
userService.delete(id);
return ResponseEntity.noContent().build();
}
}
SOAP / RPC との比較
| 項目 | REST | SOAP | gRPC |
|---|---|---|---|
| プロトコル | HTTP | HTTP / SMTP 等 | HTTP/2 |
| フォーマット | JSON / XML | XML | Protocol Buffers(バイナリ) |
| 仕様の厳密さ | 緩い(OpenAPI で補う) | 厳密(WSDL) | 厳密(.proto) |
| ペイロード | 軽い | 重い | 非常に軽い |
| ブラウザ親和性 | 高い | 低い | 低い(gRPC-Web 必要) |
| 用途 | 公開 Web API | 企業内システム | マイクロサービス間通信 |
REST API の設計ベストプラクティス
- URI は名詞の複数形 (
/users、/orders) - 階層は2 階層程度に抑える(
/users/1/ordersはOK、/users/1/orders/2/items/3/tags/4はやりすぎ) - クエリパラメータは絞り込み / ページング / ソートに(
?status=active&page=2&sort=-createdAt) - バージョニング:
/v1/usersやAccept: application/vnd.api+json;version=1 - エラーレスポンスはJSON で統一し、ステータスコード + 詳細メッセージを返す
- 認証は OAuth 2.0 / Bearer JWT が定番
- レート制限は
X-RateLimit-*ヘッダで明示
HATEOAS(応用)
真の REST(Roy Fielding が意図した “Level 3”)には HATEOAS(Hypermedia as the Engine of Application State)も含まれます。レスポンスに次に取れる操作をリンクとして埋め込み、クライアントは URL をハードコーディングせず辿るだけで API を使えるという考え方です。実際に厳密に実装するケースは少ないですが、参考としては重要。
{
"id": 1,
"name": "山田太郎",
"_links": {
"self": { "href": "/users/1" },
"orders": { "href": "/users/1/orders" },
"delete": { "href": "/users/1", "method": "DELETE" }
}
}
関連
- JAX-RS — Jakarta EE の REST API 仕様
- Jersey / RESTEasy — JAX-RS の代表実装
- Spring MVC / @RestController — Spring Boot での REST 実装
- JSON — REST API の主流データフォーマット
- OpenAPI / Swagger — REST API のスキーマ定義
- gRPC — Protocol Buffers ベースの RPC
- GraphQL — リソース指向に対するクエリベースの代替
ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子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
- MAC アドレスフィルタリングの仕組みと限界 | ネットワーク入門 NEW 2026-06-22 12:19:10
- VPNとは|暗号トンネル・サイト間/リモートアクセス・IPsec/SSL-VPN/WireGuardを解説 NEW 2026-06-22 12:19:10
- WebRTC とは ブラウザ間 P2P の音声・映像・データ通信 | ネットワーク入門 NEW 2026-06-22 12:17:25
- HTTP/2 とは 多重化・HPACK・バイナリフレーム | ネットワーク入門 NEW 2026-06-22 12:17:25
- Web通信プロトコル入門 HTTP/2・HTTP/3・WebSocket・gRPC・WebRTC | ネットワーク入門 NEW 2026-06-22 12:17:25
- gRPC とは HTTP/2 + Protocol Buffers の高速 RPC | ネットワーク入門 NEW 2026-06-22 12:17:25
- HTTP/3 (QUIC) とは UDP ベースの低遅延 Web 通信 | ネットワーク入門 NEW 2026-06-22 12:17:25
- WebSocket とは 全二重リアルタイム通信 ws/wss | ネットワーク入門 NEW 2026-06-22 12:17:25
- 証明書と認証局(CA)とは|X.509・信頼チェーン・DV/OV/EV・失効(CRL/OCSP)を解説 NEW 2026-06-22 12:17:24
- ファイアウォールとは|パケットフィルタ・ステートフル・DMZ・次世代FW(L4/L7)を解説 NEW 2026-06-22 12:17:24
- iptables/nftablesとは|テーブル・チェーン・ルール例・永続化をLinux視点で解説 NEW 2026-06-22 12:17:24
- HAProxy とは frontend/backend と設定例 | ネットワーク入門 NEW 2026-06-22 12:17:24
- CDN とは エッジキャッシュ・TTL・Cloudflare/CloudFront | ネットワーク入門 NEW 2026-06-22 12:17:24
- TLS/SSLの仕組み|ハンドシェイク・暗号スイート・前方秘匿性・証明書検証をわかりやすく解説 NEW 2026-06-22 12:17:24
コメントを削除してもよろしいでしょうか?