oneOf、anyOf 和 allOf 是 JSON Schema 規格中的關鍵字,用於定義複合資料結構。它們本質上是套用於資料驗證的邏輯運算子。Apidog 完全支援這些 JSON Schema 功能,協助你建立更精確的 API 文件與資料驗證規則。| 關鍵字 | 邏輯運算 | 條件要求 | 典型使用情境 |
|---|---|---|---|
allOf | AND | 必須同時滿足所有條件 | 繼承、擴充 |
anyOf | OR | 必須至少滿足一個條件 | 可選組合 |
oneOf | XOR | 必須剛好滿足一個條件 | 互斥選項 |
oneOf、anyOf 或 allOf。為每個子結構描述定義特定的資料結構。allOf 可讓你將多個資料結構描述組合在一起,要求資料同時滿足所有條件。這就像是說「使用者資訊必須包含基本資訊 AND 聯絡資訊」:{
"allOf": [
{
"description": "Basic user information",
"type": "object",
"properties": {
"id": { "type": "integer" },
"name": { "type": "string" }
},
"required": ["id", "name"]
},
{
"description": "Contact information",
"type": "object",
"properties": {
"email": { "type": "string", "format": "email" },
"phone": { "type": "string" }
},
"required": ["email"]
}
]
}anyOf 可提供多個可選的驗證路徑——使用者可以選擇任一種或多種方法。這就像是說「使用者可以透過使用者名稱/密碼登入 OR 電子郵件/密碼 OR 電話/驗證碼」:{
"type": "object",
"properties": {
"login": {
"anyOf": [
{
"description": "Username/password login",
"properties": {
"username": { "type": "string" },
"password": { "type": "string" }
},
"required": ["username", "password"]
},
{
"description": "Email/password login",
"properties": {
"email": { "type": "string", "format": "email" },
"password": { "type": "string" }
},
"required": ["email", "password"]
},
{
"description": "Phone/verification code login",
"properties": {
"phone": { "type": "string" },
"verifyCode": { "type": "string" }
},
"required": ["phone", "verifyCode"]
}
]
}
}
}oneOf 可確保使用者只能選擇一種付款方式,且不能同時提供多種方式。這就像是說「付款方式必須是信用卡 XOR PayPal XOR 銀行轉帳——這些選項中剛好選一個」:{
"type": "object",
"properties": {
"payment": {
"oneOf": [
{
"description": "Credit card payment",
"type": "object",
"properties": {
"type": { "const": "credit_card" },
"cardNumber": { "type": "string" },
"expiryDate": { "type": "string" }
},
"required": ["type", "cardNumber", "expiryDate"],
"additionalProperties": false
},
{
"description": "PayPal payment",
"type": "object",
"properties": {
"type": { "const": "paypal" },
"email": { "type": "string", "format": "email" }
},
"required": ["type", "email"],
"additionalProperties": false
},
{
"description": "Bank transfer",
"type": "object",
"properties": {
"type": { "const": "bank_transfer" },
"accountNumber": { "type": "string" },
"routingNumber": { "type": "string" }
},
"required": ["type", "accountNumber", "routingNumber"],
"additionalProperties": false
}
]
}
}
}allOf(AND 運算)anyOf(OR 運算)oneOf(XOR 運算)