backend-fundamentals
Auto-invoke when reviewing API routes, server logic, Express/Node.js code, or backend architecture. Enforces REST conventions, middleware patterns, and separation of concerns.
下記のコマンドをコピーしてターミナル(Mac/Linux)または PowerShell(Windows)に貼り付けてください。 ダウンロード → 解凍 → 配置まで全自動。
mkdir -p ~/.claude/skills && cd ~/.claude/skills && curl -L -o backend-fundamentals.zip https://jpskill.com/download/18277.zip && unzip -o backend-fundamentals.zip && rm backend-fundamentals.zip
$d = "$env:USERPROFILE\.claude\skills"; ni -Force -ItemType Directory $d | Out-Null; iwr https://jpskill.com/download/18277.zip -OutFile "$d\backend-fundamentals.zip"; Expand-Archive "$d\backend-fundamentals.zip" -DestinationPath $d -Force; ri "$d\backend-fundamentals.zip"
完了後、Claude Code を再起動 → 普通に「動画プロンプト作って」のように話しかけるだけで自動発動します。
💾 手動でダウンロードしたい(コマンドが難しい人向け)
- 1. 下の青いボタンを押して
backend-fundamentals.zipをダウンロード - 2. ZIPファイルをダブルクリックで解凍 →
backend-fundamentalsフォルダができる - 3. そのフォルダを
C:\Users\あなたの名前\.claude\skills\(Win)または~/.claude/skills/(Mac)へ移動 - 4. Claude Code を再起動
⚠️ ダウンロード・利用は自己責任でお願いします。当サイトは内容・動作・安全性について責任を負いません。
🎯 このSkillでできること
下記の説明文を読むと、このSkillがあなたに何をしてくれるかが分かります。Claudeにこの分野の依頼をすると、自動で発動します。
📦 インストール方法 (3ステップ)
- 1. 上の「ダウンロード」ボタンを押して .skill ファイルを取得
- 2. ファイル名の拡張子を .skill から .zip に変えて展開(macは自動展開可)
- 3. 展開してできたフォルダを、ホームフォルダの
.claude/skills/に置く- · macOS / Linux:
~/.claude/skills/ - · Windows:
%USERPROFILE%\.claude\skills\
- · macOS / Linux:
Claude Code を再起動すれば完了。「このSkillを使って…」と話しかけなくても、関連する依頼で自動的に呼び出されます。
詳しい使い方ガイドを見る →- 最終更新
- 2026-05-18
- 取得日時
- 2026-05-18
- 同梱ファイル
- 1
📖 Skill本文(日本語訳)
※ 原文(英語/中国語)を Gemini で日本語化したものです。Claude 自身は原文を読みます。誤訳がある場合は原文をご確認ください。
Backend Fundamentals Review
「APIは契約です。それを破れば、信頼を破ることになります。」
適用するタイミング
以下のレビュー時にこのスキルを有効化してください。
- API ルートハンドラ
- Express/Fastify/Hono ミドルウェア
- データベースクエリとモデル
- 認証/認可ロジック
- サーバーサイドのビジネスロジック
レビューチェックリスト
API 設計
- [ ] RESTful: ルートはRESTの規約に従っていますか? (読み込みはGET、作成はPOSTなど)
- [ ] 命名: エンドポイントは名詞ですか、動詞ですか? (
/usersであって/getUsersではない) - [ ] バージョニング: APIは将来の変更のためにバージョニングされていますか? (
/api/v1/) - [ ] ステータスコード: 正しいHTTPステータスコードが返されていますか?
関心の分離
- [ ] ルート: ルートはHTTPの関心事(req/res)のみを扱っていますか?
- [ ] コントローラ: ビジネスロジックはルートではなく、コントローラ/サービスにありますか?
- [ ] サービス: データアクセスはビジネスロジックから抽象化されていますか?
- [ ] モデル: モデルはデータの形状/バリデーションのみを担当していますか?
エラー処理
- [ ] Try/Catch: 非同期処理は適切にラップされていますか?
- [ ] エラーレスポンス: エラーは適切なステータスコードで返されていますか?
- [ ] ロギング: エラーはコンテキストとともにログに記録されていますか?
- [ ] 情報漏洩: 内部エラーはクライアントに隠されていますか?
セキュリティ
- [ ] 入力バリデーション: すべての入力は使用前にバリデーションされていますか?
- [ ] 認証: 保護されたルートは実際に保護されていますか?
- [ ] 認可: ユーザーは自分のデータにのみアクセスできますか?
- [ ] レート制限: エンドポイントは悪用から保護されていますか?
よくある間違い (アンチパターン)
1. 太ったルート
❌ app.post('/users', async (req, res) => {
// 100行のバリデーション、ビジネスロジック、DBクエリ
});
✅ app.post('/users', validateUser, userController.create);
2. 入力バリデーションなし
❌ const { email } = req.body;
await db.query(`SELECT * FROM users WHERE email = '${email}'`);
✅ const { email } = validateBody(req.body, userSchema);
await User.findByEmail(email); // パラメータ化
3. 間違ったステータスコード
❌ res.status(200).json({ error: 'Not found' });
✅ res.status(404).json({ error: 'User not found' });
4. 内部エラーの漏洩
❌ catch (error) {
res.status(500).json({ error: error.message, stack: error.stack });
}
✅ catch (error) {
logger.error('User creation failed', { error, userId });
res.status(500).json({ error: 'Something went wrong' });
}
ソクラテス式質問
ジュニアに答えを与える代わりに、これらの質問をしてください。
- アーキテクチャ: 「ExpressからFastifyに切り替えたい場合、何を変更する必要がありますか?」
- バリデーション: 「誰かが不正なJSONを送信したらどうなりますか?」
- 認証: 「このユーザーがこのリソースを所有していることをどのように知っていますか?」
- エラー: 「データベースがダウンしているとき、クライアントは何を見ますか?」
- テスト: 「このエンドポイントを単独でテストするにはどうすればよいですか?」
HTTPステータスコードリファレンス
| Code | 使用するタイミング |
|---|---|
| 200 | 成功 (ボディあり) |
| 201 | 作成済み (POST後) |
| 204 | 成功 (コンテンツなし、DELETE後) |
| 400 | 不正なリクエスト (バリデーション失敗) |
| 401 | 認証されていません (ログインしていない) |
| 403 | 禁止されています (ログインしているが許可されていない) |
| 404 | 見つかりません |
| 409 | 競合 (リソースの重複) |
| 500 | サーバーエラー (クライアントに詳細を隠す) |
アーキテクチャレイヤー
Request → Route → Controller → Service → Repository → Database
↓
Middleware (auth, validation, logging)
| Layer | 責任 |
|---|---|
| Route | HTTP動詞、パス、ミドルウェアチェーン |
| Controller | リクエスト/レスポンスの処理、サービスの呼び出し |
| Service | ビジネスロジック、オーケストレーション |
| Repository | データアクセス、クエリ |
指摘すべき危険信号
| Flag | 尋ねるべき質問 |
|---|---|
| ルートハンドラ内のSQL | 「データアクセスは別のレイヤーにあるべきではないですか?」 |
| asyncにtry/catchがない | 「これが失敗したらどうなりますか?」 |
| req.bodyを直接使用 | 「誰かが予期しないフィールドを送信したらどうなりますか?」 |
| ハードコードされたシークレット | 「これは本番環境でどのように機能しますか?」 |
| リストエンドポイントにページネーションがない | 「10,000件のレコードがある場合はどうなりますか?」 |
📜 原文 SKILL.md(Claudeが読む英語/中国語)を展開
Backend Fundamentals Review
"APIs are contracts. Break them, and you break trust."
When to Apply
Activate this skill when reviewing:
- API route handlers
- Express/Fastify/Hono middleware
- Database queries and models
- Authentication/authorization logic
- Server-side business logic
Review Checklist
API Design
- [ ] RESTful: Do routes follow REST conventions? (GET for read, POST for create, etc.)
- [ ] Naming: Are endpoints nouns, not verbs? (
/usersnot/getUsers) - [ ] Versioning: Is API versioned for future changes? (
/api/v1/) - [ ] Status Codes: Are correct HTTP status codes returned?
Separation of Concerns
- [ ] Routes: Do routes only handle HTTP concerns (req/res)?
- [ ] Controllers: Is business logic in controllers/services, not routes?
- [ ] Services: Is data access abstracted from business logic?
- [ ] Models: Are models responsible only for data shape/validation?
Error Handling
- [ ] Try/Catch: Are async operations wrapped properly?
- [ ] Error Responses: Are errors returned with proper status codes?
- [ ] Logging: Are errors logged with context?
- [ ] No Leaks: Are internal errors hidden from clients?
Security
- [ ] Input Validation: Is ALL input validated before use?
- [ ] Authentication: Are protected routes actually protected?
- [ ] Authorization: Can users only access their own data?
- [ ] Rate Limiting: Are endpoints protected from abuse?
Common Mistakes (Anti-Patterns)
1. Fat Routes
❌ app.post('/users', async (req, res) => {
// 100 lines of validation, business logic, DB queries
});
✅ app.post('/users', validateUser, userController.create);
2. No Input Validation
❌ const { email } = req.body;
await db.query(`SELECT * FROM users WHERE email = '${email}'`);
✅ const { email } = validateBody(req.body, userSchema);
await User.findByEmail(email); // parameterized
3. Wrong Status Codes
❌ res.status(200).json({ error: 'Not found' });
✅ res.status(404).json({ error: 'User not found' });
4. Leaking Internal Errors
❌ catch (error) {
res.status(500).json({ error: error.message, stack: error.stack });
}
✅ catch (error) {
logger.error('User creation failed', { error, userId });
res.status(500).json({ error: 'Something went wrong' });
}
Socratic Questions
Ask the junior these questions instead of giving answers:
- Architecture: "If I wanted to switch from Express to Fastify, what would need to change?"
- Validation: "What happens if someone sends malformed JSON?"
- Auth: "How do you know this user owns this resource?"
- Errors: "What does the client see when the database is down?"
- Testing: "How would you test this endpoint in isolation?"
HTTP Status Code Reference
| Code | When to Use |
|---|---|
| 200 | Success (with body) |
| 201 | Created (after POST) |
| 204 | Success (no content, after DELETE) |
| 400 | Bad request (validation failed) |
| 401 | Unauthorized (not logged in) |
| 403 | Forbidden (logged in but not allowed) |
| 404 | Not found |
| 409 | Conflict (duplicate resource) |
| 500 | Server error (hide details from client) |
Architecture Layers
Request → Route → Controller → Service → Repository → Database
↓
Middleware (auth, validation, logging)
| Layer | Responsibility |
|---|---|
| Route | HTTP verbs, paths, middleware chain |
| Controller | Request/response handling, calling services |
| Service | Business logic, orchestration |
| Repository | Data access, queries |
Red Flags to Call Out
| Flag | Question to Ask |
|---|---|
| SQL in route handler | "Should data access be in a separate layer?" |
| No try/catch on async | "What happens if this fails?" |
| req.body used directly | "What if someone sends unexpected fields?" |
| Hardcoded secrets | "How would this work in production?" |
| No pagination on list endpoints | "What if there are 10,000 records?" |