Validation JSON Schema

VérifiéSûr

Développer et corriger les fonctionnalités de validation JSON Schema pour l'enregistrement utilisateur, la vérification d'identité et les API externes, en conformité avec le Draft 2020-12.

Spar Skills Guide Bot
DeveloppementIntermédiaire
3002/06/2026
Claude Code
#json-schema#validation#identity-verification#user-registration

Recommandé pour

Notre avis

Ce skill guide le développement et la correction de la validation de schéma JSON au sein d'un serveur IDP, couvrant l'enregistrement utilisateur, la vérification d'identité et la validation d'API externes.

Points forts

  • Conforme à JSON Schema Draft 2020-12, une version moderne et largement supportée.
  • Gère des cas d'usage variés : inscription utilisateur, vérification d'identité, API externes.
  • Fournit des messages d'erreur détaillés par champ, facilitant le débogage.
  • Support de schémas personnalisés par tenant pour une flexibilité métier.

Limites

  • Intégré dans une base de code spécifique (projet IDP), non réutilisable directement.
  • Nécessite une bonne connaissance de JSON Schema pour créer ou modifier les définitions.
  • La validation repose sur des classes Java prédéfinies, limitant les extensions rapides.
Quand l'utiliser

Utilisez ce skill lorsque vous devez implémenter ou modifier la validation de schéma JSON dans le contexte d'un serveur IDP, notamment pour l'enregistrement utilisateur ou la vérification d'identité.

Quand l'éviter

Ne l'utilisez pas pour un projet n'utilisant pas l'architecture décrite ou si vous avez besoin d'une bibliothèque de validation générique et indépendante.

Analyse de sécurité

Sûr
Score qualité85/100

The skill contains no executable instructions, no use of tools, and only provides documentation and code examples for JSON schema validation. It poses no security risk.

Aucun point d'attention détecté

Exemples

Add a new optional field to user registration schema
Add a field 'phone' to the user registration JSON schema. It should be a string with a phone format (pattern: '^\+[1-9]\d{1,14}$') and optional.
Fix email format validation error
The email field in the user registration schema is rejecting valid email addresses. Check the JSON Schema validator implementation and ensure it uses the correct email format validation.
Implement external API response validation
Create a new JSON schema definition for validating responses from an external API. The response should have fields: 'status' (integer), 'data' (object), and 'message' (string). Make 'status' and 'data' required.

name: spec-json-schema description: JSONスキーマ検証(JSON Schema Validation)機能の開発・修正を行う際に使用。ユーザー登録スキーマ、Identity Verificationスキーマ、外部API検証実装時に役立つ。

JSONスキーマ検証(JSON Schema Validation)開発ガイド

ドキュメント

  • documentation/docs/content_03_concepts/06-security-extensions/concept-03-schema-validation.md - JSONスキーマ検証概念

機能概要

JSONスキーマ検証は、入力データの構造・型・制約を検証する層。

  • JSON Schema Draft 2020-12準拠
  • ユーザー登録検証: テナント別カスタムスキーマ
  • Identity Verification検証: 本人確認申請データ検証
  • 外部API検証: リクエスト/レスポンス検証
  • 詳細エラーメッセージ: フィールド別エラー

モジュール構成

libs/
└── idp-server-platform/                     # プラットフォーム基盤
    └── .../platform/json/schema/
        ├── JsonSchemaDefinition.java       # スキーマ定義
        ├── JsonSchemaValidator.java        # スキーマ検証
        └── JsonSchemaValidationException.java

ユーザー登録でのスキーマ検証

idp-server-core/openid/identity/IdPUserCreator.java 内:

public class IdPUserCreator {

    JsonSchemaDefinition definition;
    AuthenticationInteractionRequest request;

    public User create() {
        User user = User.initialized();

        // スキーマ定義に基づいてフィールドを設定
        if (definition.hasProperty("name") &&
            request.containsKey("name")) {
            user.setName(request.getValueAsString("name"));
        }

        if (definition.hasProperty("email") &&
            request.containsKey("email")) {
            user.setEmail(request.getValueAsString("email"));
        }

        // その他のフィールドも同様に処理
        // ...

        return user;
    }
}

注意: JsonSchemaDefinitionが、許可されたフィールドを定義します。

スキーマ定義例

ユーザー登録スキーマ

{
  "$schema": "https://json-schema.org/draft/2020-12/schema",
  "type": "object",
  "properties": {
    "email": {
      "type": "string",
      "format": "email"
    },
    "name": {
      "type": "string",
      "minLength": 1,
      "maxLength": 100
    },
    "birthdate": {
      "type": "string",
      "pattern": "^[0-9]{4}-[0-9]{2}-[0-9]{2}$"
    }
  },
  "required": ["email", "name"]
}

Identity Verification申請スキーマ

{
  "$schema": "https://json-schema.org/draft/2020-12/schema",
  "type": "object",
  "properties": {
    "document_type": {
      "type": "string",
      "enum": ["passport", "drivers_license", "national_id"]
    },
    "document_number": {
      "type": "string",
      "minLength": 5
    }
  },
  "required": ["document_type", "document_number"]
}

スキーマ検証エラー

public class JsonSchemaValidationException {
    // フィールド別の詳細エラーメッセージ
    // - 必須フィールド不足
    // - 型不一致
    // - フォーマット違反
    // - 制約違反(minLength, maxLength, pattern等)
}

E2Eテスト

e2e/src/tests/
└── integration/ida/
    └── (Identity Verificationスキーマ検証テスト)

コマンド

# ビルド
./gradlew :libs:idp-server-platform:compileJava

# テスト
cd e2e && npm test -- integration/ida/

トラブルシューティング

スキーマ検証失敗

  • スキーマ定義が正しいか確認(JSON Schema Draft 2020-12形式)
  • 必須フィールドが含まれているか確認

型エラー

  • フィールドの型がスキーマと一致するか確認
  • string, number, boolean, object, arrayを正しく使用

フォーマット検証失敗

  • email, uri, date-time等のフォーマットが正しいか確認
  • カスタムpattern(正規表現)が正しいか確認

カスタムスキーマが反映されない

  • テナント別スキーマ設定が正しいか確認
  • JsonSchemaDefinitionが正しくロードされているか確認
Skills similaires