JSON - स्कीमा

JSON स्कीमा JSON डेटा की संरचना को परिभाषित करने के लिए JSON आधारित प्रारूप के लिए एक विनिर्देश है। यह IETF ड्राफ्ट के तहत लिखा गया था जो 2011 में समाप्त हो गया था। JSON स्कीमा -

  • आपके मौजूदा डेटा प्रारूप का वर्णन करता है।
  • स्पष्ट, मानव- और मशीन-पठनीय प्रलेखन।
  • पूर्ण संरचनात्मक सत्यापन, स्वचालित परीक्षण के लिए उपयोगी।
  • क्लाइंट-सबमिट किए गए डेटा को मान्य करते हुए संरचनात्मक सत्यापन पूरा करें।

JSON स्कीमा मान्यता पुस्तकालय

वर्तमान में विभिन्न प्रोग्रामिंग भाषाओं के लिए कई सत्यापनकर्ता उपलब्ध हैं। वर्तमान में उपलब्ध सबसे पूर्ण और आज्ञाकारी JSON स्कीमा सत्यापनकर्ता JSV है।

बोली पुस्तकालयों
सी WJElement (LGPLv3)
जावा json-schema-validator (LGPLv3)
नेट Json.NET (MIT)
एक्शनस्क्रिप्ट 3 फ़्रिगा (MIT)
हास्केल ऐसन-स्कीमा (MIT)
अजगर Jsonschema
माणिक ऑटोपरसे (एएसएल 2.0); रूबी- jsonschema (MIT)
पीएचपी php-json-schema (MIT)। json-schema (बर्कले)
जावास्क्रिप्ट अर्दली (बीएसडी); JSV; json-स्कीमा; Matic (MIT); डोजो; Persevere (संशोधित BSD या AFL 2.0); schema.js।

JSON स्कीमा उदाहरण

नीचे एक बुनियादी JSON स्कीमा दिया गया है, जो एक शास्त्रीय उत्पाद सूची विवरण को कवर करता है -

{
   "$schema": "http://json-schema.org/draft-04/schema#",
   "title": "Product",
   "description": "A product from Acme's catalog",
   "type": "object",
	
   "properties": {
	
      "id": {
         "description": "The unique identifier for a product",
         "type": "integer"
      },
		
      "name": {
         "description": "Name of the product",
         "type": "string"
      },
		
      "price": {
         "type": "number",
         "minimum": 0,
         "exclusiveMinimum": true
      }
   },
	
   "required": ["id", "name", "price"]
}

आइए इस स्कीमा में उपयोग किए जा सकने वाले विभिन्न महत्वपूर्ण कीवर्ड देखें -

अनु क्रमांक। कीवर्ड और विवरण
1

$schema

$ स्कीमा कीवर्ड बताता है कि यह स्कीमा ड्राफ्ट v4 विनिर्देश के अनुसार लिखा गया है।

2

title

अपने स्कीमा को शीर्षक देने के लिए आप इसका उपयोग करेंगे।

3

description

स्कीमा का थोड़ा विवरण।

4

type

टाइप कीवर्ड हमारे JSON डेटा पर पहले बाधा को परिभाषित करता है: इसे JSON ऑब्जेक्ट होना चाहिए।

5

properties

JSON फ़ाइल में उपयोग किए जाने वाले विभिन्न कुंजी और उनके मान प्रकार, न्यूनतम और अधिकतम मान को परिभाषित करता है।

6

required

यह आवश्यक गुणों की एक सूची रखता है।

7

minimum

यह मूल्य पर लगाया जाने वाला अवरोध है और न्यूनतम स्वीकार्य मूल्य का प्रतिनिधित्व करता है।

8

exclusiveMinimum

यदि "अनन्यतम" मौजूद है और बूलियन मान सत्य है, तो उदाहरण मान्य है यदि यह "न्यूनतम" के मूल्य से अधिक है।

9

maximum

यह मूल्य पर लगाया जाने वाला अवरोध है और अधिकतम स्वीकार्य मूल्य का प्रतिनिधित्व करता है।

10

exclusiveMaximum

यदि "एक्सक्लूसिव मैक्सिमम" मौजूद है और बूलियन वैल्यू सही है, तो उदाहरण मान्य है यदि यह "अधिकतम" के मान से कड़ाई से कम है।

1 1

multipleOf

एक संख्यात्मक उदाहरण "multipleOf" के खिलाफ मान्य है यदि इस कीवर्ड के मान द्वारा विभाजन का परिणाम पूर्णांक है।

12

maxLength

एक स्ट्रिंग आवृत्ति की लंबाई को इसके वर्णों की अधिकतम संख्या के रूप में परिभाषित किया गया है।

13

minLength

एक स्ट्रिंग आवृत्ति की लंबाई को इसके वर्णों की न्यूनतम संख्या के रूप में परिभाषित किया गया है।

14

pattern

एक स्ट्रिंग उदाहरण को वैध माना जाता है यदि नियमित अभिव्यक्ति उदाहरण से सफलतापूर्वक मेल खाती है।

आप एक की जाँच कर सकते हैं http://json-schema.orgउन कीवर्ड की पूरी सूची के लिए जिनका उपयोग JSON स्कीमा को परिभाषित करने में किया जा सकता है। उपरोक्त स्कीमा का उपयोग निम्नलिखित JSON कोड की वैधता का परीक्षण करने के लिए किया जा सकता है -

[
   {
      "id": 2,
      "name": "An ice sculpture",
      "price": 12.50,
   },
	
   {
      "id": 3,
      "name": "A blue mouse",
      "price": 25.50,
   }
]