జేసన్ సరైనదికాని నిర్ధారికర్త
అగ్రశ్రేణి ఆన్లైన్ JSON వాక్యరచనా నిర్ధారక మరియు స్కీమా చెకర్—పూర్తిగా బ్రౌజర్ ఆధారితమైనది మరియు గోప్యతా ప్రాధాన్యత కలిగినది.
మీ JSON ని వెంటనే ధృవీకరించండి
ఈ ఉచిత ఆన్లైన్ JSON వెరిఫైయర్ మీ JSON డేటాను తక్షణమే సింటాక్స్ లోపాలు మరియు నిర్మాణ సంబంధ సమస్యల కోసం తనిఖీ చేయడానికి సహాయపడుతుంది. మీరు రా API ప్రతిస్పందనలు, కాన్ఫిగరేషన్ ఫైల్స్, లేదా నిర్మిత పేఎల్స్ను వెరిఫై చేయాలనుకున్నా, మా టూల్ సమస్యలను నిజకాలంలో హైలైట్ చేస్తుంది మరియు స్వతంత్రమైన సరిదిద్దల ఇస్తుంది. మరింత కచ్చితమైన వెరిఫైకి, JSON స్కీమాను జతచేసి అవసరమైన ఫీల్డ్స్, నిర్దిష్ట రకాలూ, ఫార్మాట్లు (ఈమెయిల్, URI, మొదలైనవి) వంటి నియమాలను అమలు చేయండి. ఈ టూల్ పూర్తి JSON Schema Draft-07 ప్రమాణాలకు అనుగుణంగా ఉంటుంది. అన్ని ప్రాసెసింగ్ మీ బ్రౌజర్లో జరుగుతుంది—మీ డేటా ఎప్పుడూ మీ యంత్రం నించి బయటకు వెళ్లదు.
JSON ధ్రువీకరణ అంటే ఏమిటి?
JSON (జావాస్క్రిప్ట్ آب్జెక్ట్ నోటేషన్) అనేది విస్తృతంగా ఉపయోగించే, తేలికపాటి డేటా మార్చుకొనే ఫార్మాట్, ఇది మనుష్యులకి సులభంగా చదవగలిగే విధంగా మరియు యంత్రాలు కూడా సులభంగా విశ్లేషించగలిగేలా రూపొందించబడింది. దాని ముఖ్య లక్ష్యం నిర్మిత డేటా—ఆబ్జెక్టులు, అరేలు, స్ట్రింగ్లు, సంఖ్యలు, బూలియన్లు, మరియు నల్ విలువలను—భాషాపరమైన పరిమితుల లేని విధంగా ప్రదర్శించడం.
JSON సరిచూసే ప్రక్రియ అనేది ఒక JSON డాక్యుమెంట్ వ్యాకరణాత్మకంగా మరియు నిర్మాణాత్మకంగా సరైనదేనా అని ప్రోగ్రామాటిక్గా నిర్ధారించటం. దీని రెండు ముఖ్య అంశాలు ఉంటాయి:
- వ్యాకరణ ప్రమాణం: క్రూడ్ టెక్స్ట్ ECMA-404 JSON స్పెసిఫికేషన్ ద్వారా నిర్వచించిన అధికారిక వ్యాకరణాన్ని అనుసరిస్తుందో లేదో నిర్ధారించడం. ఆధునిక ప్రోగ్రామింగ్ లాంగ్వేజీలలోని పార్సర్లు (ఉదాహరణకు, జావాస్క్రిప్ట్లో JSON.parse(), పైథాన్లో json.loads(), జావాలో JSONDecoder) సరైన సింటాక్స్ను ఆశిస్తాయి, ఇన్పుట్ తప్పుగా ఉంటే ఎర్రర్లు చూపిస్తాయి.
- స్ట్రక్చరల్ (స్కీమా) తనిఖี: సింటాక్స్ కు బయటకు, స్కీమా ధ్రువీకరణ JSON డేటా ఆశించిన నిర్మాణంతో సరిపోలుతుందా అనే 것을 తనిఖీ చేస్తుంది, ఇందులో డేటా రకాల, అవసరమైన లక్షణాలు, విలువ పరిమితులు మరియు నెస్టెడ్ ఆబ్జెక్ట్లు/అarrayలు ఉంటాయి. స్కీమా ధ్రువీకరణ సాధారణంగా JSON స్కీమా ఉపయోగించి చేయబడుతుంది, ఇది చెల్లుబాటు డేటా కోసం నియమాలను నిర్వచిస్తుంది.
JSONని ఎందుకు ధృవీకరించాలి?
డేటా ప్రసారం, నిల్వ లేదా సర్వీసుల మధ్య కమ్యూనికేషన్ కోసం సీరియలైజ్ చేయబడినప్పుడు JSON ధృవీకరణ అత్యంత ముఖ్యమైనది. ముఖ్య కారణాలు ఈ క్రింది విధంగా ఉన్నాయి:
- లోపాల నివారణ: డేటాను ప్రాసెస్ చేసేమునకు ముందు సింటాక్స్ లోపాలను (ఉదా: వాక్య విడిగా ఉండకపోవడం, అసమతుల్యమైన గడపలు, చట్టవిరుద్ధ అక్షరాలు) తొలగించడంలో గుర్తించి నివేదించండి.
- డేటా సమగ్రత మరియు భద్రత: తప్పుగా నిర్మితమైన లేదా దుష్టమైన JSON పేళ్ళను తిరస్కరించడం, బ్యాక్ఎండ్ క్రాష్లు, ఇంజెక్షన్ بریدులు లేదా డేటా కలుపుదల నివారణకు సహాయం చేస్తుంది.
- టైప్ సేఫ్టీ: కఠినమైన టైపింగ్ను పాటించండి—ఉదాహరణకు, ఒక ఫీల్డ్ బూలియన్గా ఉండాల్సినది స్ట్రింగ్గా పంపకూడదని, లేదా UUIDలు, ఇమెయిల్స్, సంఖ్యలు సక్రమమైన ఫార్మాట్లో ఉంటాయని నిర్ధారించుకోండి.
- భాషల అంతర్మేళనం: ఒక వాతావరణంలో (ఉదాహరణకు, Node.js) ఉత్పత్తి చేయబడిన JSON ను మరో వాతావరణంలో (ఉదాహరణకు, Python, Go, Java) సురక్షితంగా ఉపయోగించుకునేలా నిర్ధారించండి, సీరియలైజేషన్/డీసీరియలైజేషన్ దోషాలు నివారించండి.
- నిర్వహణ సౌలభ్యం మరియు బలంగా ఉండటం: ధృవీకరించబడిన డేటా నిర్మాణాలు ట్రేసబిలిటీని మెరుగుపరిచి, కాన్ఫిగరేషన్ ఫైళ్లలో, లాగ్లలో లేదా API అభ్యర్థనలు/ప్రతిస్పందనలలో డీబగ్గింగ్ చేయడానికి కష్టమైన పొరపాట్ల ప్రమాదాన్ని తగ్గిస్తాయి.
- గోప్యత & భద్రత: వాలిడేషన్ పూర్ణంగా క్లయింట్-సైడ్ (బ్రౌజర్లో) నిర్వహించవచ్చు, ఇది వాడుకరి పరికరం నుండి rå లేదా సెన్సిటివ్ డేటా వెళ్ళకుండా నిరోధిస్తుంది.
సాధారణ JSON ధృవీకరణ తప్పులు (వివరణాత్మక ఉదాహరణలతో)
అరోపణ చేయని కీలు
JSON ఆబ్జెక్టులలోని అన్ని కీలు తప్పకుండా డబుల్ గుండ్రటి కోట్లలో ఉండాలి.
{ name: "అలీస్" }
{ "name": "అలిస్" }
చాలా JSON వంటి ఫార్మాట్లు (ఉదాహరణకు, జావాస్క్రిప్ట్ ఆబ్జెక్ట్ లిటరల్స్) ఉట్గీకరించని కీలు అనుమతిస్తాయి, కానీ సాధారణ JSON ఇది అనుమతించదు.
సింగిల్ కోట్స్
JSON స్ట్రింగ్లు రెండుసార్ల కొటేషన్లను మాత్రమే ఉపయోగించాలి; ఒంటరి కొటేషన్లు అనుమతించబడవు.
{ 'name': 'బాబ్' }
{ "name": "బాబ్" }
ఒకే ఒరుబడిగా సింగిల్ కోట్స్ ఉపయోగించడం అన్ని కాంఫ్లయింట్ JSON లైబ్రరీలలో పార్సర్ తప్పిదాలను కలిగిస్తుంది.
చివరి కామాలు
ఒక ఆబ్జెక్ట్ లేదా ఏరేకు చివర సరి తర్వాత ఎక్కడా కామా ఉండకూడదు.
{ "a": 1, "b": 2, }
{ "a": 1, "b": 2 }
JavaScriptలో ట్రైలింగ్ కామాలు పనిచేయవచ్చు, కానీ కఠినమైన JSON పార్సర్లలో అవి పనిచేయవు.
అక్షరాల తప్పు తప్పించుకోవడం
స్ట్రింగ్లలో ఉన్న కోట్స్ మరియు ప్రత్యేక అక్షరాలను బ్యాక్స్లాష్ వాడుతూ ఎస్కేప్ చేయాలి.
{ "quote": "టామ్ 'హలో' అన్నాడు" }
{ "quote": "టామ్ చెప్పారు \"హలో\"" }
ఇతర ఎస్కేప్ సీక్వెన్సులు \\ బ్యాక్స్లాష్ కోసం, \n కొత్త పంక్తుల కోసం, మరియు \t ట్యాబ్లు కోసం ఉంటాయి.
తప్పు డేటా రకాలు
నంబర్లు, బూలియన్స్ లేదా నల్ విలువలకు స్ట్రింగ్స్ ఉపయోగించవద్దు.
{ "enabled": "సయంజమైనది", "count": "10" }
{ "enabled": నిజం, "count": 10 }
JSON బూలియన్లు, సంఖ్యలు, స్ట్రింగులను పకడ్బందీగా వేరు చేస్తుంది—సరైన డేటా టైప్ వాడటం నిర్ధారించుకోండి.
అ ప్రాథమిక కీలు
JSON ఆబ్జెక్ట్ కీలు ఎప్పుడూ స్ట్రింగ్స్ గా ఉండాలి; సంఖ్యలు, బూలియన్లు లేదా ఇతర రకాలును కీలు గా ఉపయోగించలేరు.
{ 123: "ఎಬిసి" }
{ "123": "abc" }
ప్రతిరూప కీలు
JSON స్పెక్స్ అనుమతించినప్పటికీ, నకిలీ కీలు పొరపాట్లకి సాధారణ కారణం అవుతుంటాయి.
{ "name": "ఆలిస్", "name": "బాబ్" }
చాలా పర్షర్లు కేవలం చివరి విలువ ("బాబ్")ని మాత్రమే ఉంచుతారు, ముందున్న విలువలను మూల్యాంకనం లేకుండా తొలగిస్తారు.
వ్యాఖ్యల ఉపయోగం
స్టాండర్డ్ JSON లో కామెంట్లు అనుమతించబడవు, అయితే కొన్ని ఎడిటర్లు వాటిని మద్దతు ఇస్తాయి.
{ // వినియోగదారు సమాచారం "name": "అలిస్" }
{ "name": "అలిస్" }
స్కీమా ధృవీకరణ: నిర్మాణం మరియు డేటా రకాలపై కఠిన నియంత్రణ
JSON స్కీమా అనేది JSON డాక్యుమెంట్ల ఊహించిన నిర్మాణాన్ని నిర్వచించడానికి మరియు ధృవీకరించడానికి శక్తివంతమైన ప్రమాణం. ఇది మీరు ఈ వివరాలను నిర్దారించడానికి అనుమతిస్తుంది:
- అవసరమైన రంగాలు (`required`)
- డేటా రకాల (`type`: స్ట్రింగ్, నంబర్, బూలియన్, ఆబ్జెక్ట్, అర్రే, నల్ల)
- స్ట్రింగ్ ఆకారాలు (`format`: ఇమెయిల్, UUID, తేదీ-సమయం, మొదలైనవి)
- స్ట్రింగుల కోసం నమూనా సరిపోక (ప్యాటర్న్ మ్యాచింగ్) (`pattern`)
- సంఖ్య శ్రేణులు (`కనీసం`, `గరిష్టం`)
- అర్రే పొడవు మరియు అంశాల ధృవీకరణ (`minItems`, `maxItems`, `items`)
- ఆబ్జెక్టులు మరియు అరేలకు అంతర్గత ధృవీకరణ
- ఎనమ్ పరిమితులు (`enum`)
ఉదాహరణ: యూజర్ స్కీమా (డ్రాఫ్ట్-07)
{ "type": "object", "properties": { "id": { "type": "string", "format": "uuid" }, "name": { "type": "string", "minLength": 1, "description": "పూర్తి పేరు" }, "email": { "type": "string", "format": "email", "description": "ఇమెయిల్ చిరునామా" }, "is_active": { "type": "boolean", "description": "చురుకుగా ఉంది" } }, "required": ["id", "name", "email"], "additionalProperties": false }
ఇది అమలుచేస్తుంది:
- id ఒక సరైన UUID స్ట్రింగ్ అయి ఉండాలి.
- పేరు ఖాళీ కాని స్ట్రింగ్గా ఉండాలి.
- ఇమెయిల్ సాధారణ ఇమెయిల్ ఫార్మాట్కు తగినట్లు ఉండాలి.
- is_active (ఐచ్ఛికం) ఒక బూలియన్ అయి ఉండాలి.
- పైన నిర్వచించినవి తప్ప మరే ఇతర ప్రాపర్టీలు అనుమతించబడవు.
నిజమైన ఉదాహరణ: స్ట్రైప్ API స్పందనలను ధృవీకరిస్తోంది
మీరు Stripe API (ఉదాహరణకు, PaymentIntent) నుండి JSON స్పందనలను అందుకుంటారని ఊహించుకుందాం. స్కీమా ప్రమాణ శాసనం ద్వారా మీరు ఎప్పుడూ అసంపూర్ణమైన లేదా తప్పు రకమైన డేటాను ప్రాసెస్ చేయకుండా నిర్ధారించవచ్చు.
{ "type": "object", "properties": { "id": { "type": "string", "pattern": "^pi_" }, "object": { "type": "string", "const": "payment_intent" }, "amount": { "type": "integer", "minimum": 1 }, "currency":{ "type": "string", "minLength": 3, "maxLength": 3 }, "status": { "type": "string", "enum": [ "చెల్లింపు పద్ధతి అవసరం", "నిర్ధారణ అవసరం", "ప్రాసెసింగ్లో ఉంది", "విజయవంతమైంది", "రద్దు చేయబడింది" ]} }, "required": ["id", "object", "amount", "currency", "status"], "additionalProperties": false }
- ఐడి "pi_" తో ప్రారంభమవ్వాలి
- ఆబ్జెక్ట్ ఎప్పుడు "payment_intent" అయి ఉండాలి
- మొత్తం 1 లేదా దానికంటే ఎక్కువ పూర్తి సంఖ్యగా ఉండాలి
- కరెన్సీ మూడు అక్షరాల స్ట్రింగ్ కావాలి (ఉదా: "usd", "eur")
- స్థితి నిర్దిష్టించబడిన విలువలలో ఒకటి అయివుండాలి
లాభాలు
- ప్రారంభ లోపాల గుర్తింపు: మీ వ్యాపార లాజిక్కు చేరిపోకుండా ముందుగా API మార్పులు లేదా అసంపూర్ణ డేటాను గుర్తించండి.
- స్వయంచాలక పరీక్ష: వాస్తవ మరియు మాక్ ప్రతిస్పందనలను ధృవీకరించడానికి CI/CD పైప్లైన్లలో స్కీమాలను ఉపయోగించండి.
- క్రాస్-టీమ్ సారూప్యత: ఫ్రంటెండ్, బెకెండ్, మరియు తృతీయ পক্ষ APIల మధ్య డేటా ఒప్పందాలను ప్రామాణీకరించండి.
సరైన JSON తనిఖీ—సింటాక్స్ మరియు స్కీమాను రెండింటినీ కవర్ చేయటం—సూక్ష్మ బగ్స్ ను నిరోధిస్తుంది, ఉత్తమ పద్ధతులను అమలు చేస్తుంది, మరియు తప్పు లేదా దుష్టమైన ఇన్పుట్ నుండి మీ యాప్లను రక్షిస్తుంది. కాన్ఫిగరేషన్ ఫైళ్ళ్లోనైనా, API పేటల్స్ లోనైనా, లేదా సర్వీస్ల మధ్య సందేశాలలోనైనా వాడినప్పుడు, బలమైన తనిఖీ ఆధునిక సాఫ్ట్వేర్ సిస్టమ్లకు ముఖ్యం.
ప్రైవసీ & సెక్యూరిటీ
అన్ని వాలిడేషన్ మరియు స్కీమా చెక్లు మీ బ్రౌజర్లో స్థానికంగా నిర్వహింపబడతాయి. ఎలాంటి డేటా అప్లోడ్ లేదా లాగ్ చేయబడదు. మీ JSON పూర్తిగా ప్రైవేట్గా ఉంటుంది.
JSON చెల్లింపు కోడ్ ఉదాహరణలు
ప్రత్యేకంగా రూపొందించిన లైబ్రరీలు లేదా ప్రాచీన ఫ్రేమ్వర్క్లను ఉపయోగించి వివిధ ప్రోగ్రామింగ్ భాషల్లో JSON ను ఎలా ధ్రువీకరించాలో చూడండి. ఈ ఉదాహరణలు వాక్య నిర్మాణ ధ్రువీకరణ మరియు స్కీమా ధ్రువీకరణ రెండింటినీ సమగ్రంగా చూపుతాయి.
const jsonString = '{"name":"Alice","age":30}';
try {
const obj = JSON.parse(jsonString);
console.log("Valid JSON:", obj);
} catch (e) {
console.error("Invalid JSON!", e.message);
}
const Ajv = require("ajv");
const ajv = new Ajv();
const schema = { type: "object", properties: { age: { type: "integer" } }, required: ["age"] };
const data = { age: 30 };
const validate = ajv.compile(schema);
console.log(validate(data) ? "Valid!" : ajv.errorsText(validate.errors));
import json
try:
obj = json.loads('{"name":"Alice","age":30}')
print("Valid JSON:", obj)
except json.JSONDecodeError as e:
print("Invalid JSON:", e)
import json, jsonschema
schema = {
"type": "object",
"properties": { "age": { "type": "integer" } },
"required": ["age"]
}
data = {"age": 30}
try:
jsonschema.validate(data, schema)
print("Valid!")
except jsonschema.ValidationError as e:
print("Schema validation error:", e)
package main
import (
"encoding/json"
"fmt"
)
func main() {
data := []byte(`{"name":"Alice","age":30}`)
var obj map[string]interface{}
if err := json.Unmarshal(data, &obj); err != nil {
fmt.Println("Invalid JSON:", err)
} else {
fmt.Println("Valid JSON:", obj)
}
}
import com.fasterxml.jackson.databind.ObjectMapper;
public class Main {
public static void main(String[] args) {
String json = "{"name":"Alice","age":30}";
try {
Object obj = new ObjectMapper().readTree(json);
System.out.println("Valid JSON: " + obj);
} catch (Exception e) {
System.out.println("Invalid JSON: " + e.getMessage());
}
}
}
using System;
using System.Text.Json;
class Program {
static void Main() {
string json = "{"name":"Alice","age":30}";
try {
var doc = JsonDocument.Parse(json);
Console.WriteLine("Valid JSON!");
} catch (JsonException e) {
Console.WriteLine("Invalid JSON: " + e.Message);
}
}
}
<?php
$json = '{"name":"Alice","age":30}';
$obj = json_decode($json);
if (json_last_error() === JSON_ERROR_NONE) {
echo "Valid JSON";
} else {
echo "Invalid JSON: " . json_last_error_msg();
}
require 'json'
begin
obj = JSON.parse('{"name":"Alice","age":30}')
puts "Valid JSON!"
rescue JSON::ParserError => e
puts "Invalid JSON: #{e.message}"
end
echo '{"name":"Alice","age":30}' | jq empty && echo "Valid" || echo "Invalid"
fn main() {
let data = r#"{"name":"Alice","age":30}"#;
match serde_json::from_str::<serde_json::Value>(data) {
Ok(_) => println!("Valid JSON!"),
Err(e) => println!("Invalid JSON: {}", e),
}
}
import org.json.JSONObject
fun main() {
try {
val obj = JSONObject("{\"name\":\"Alice\",\"age\":30}")
println("Valid JSON: $obj")
} catch (e: Exception) {
println("Invalid JSON: ${e.message}")
}
}
import Foundation
let json = "{\"name\":\"Alice\",\"age\":30}"
if let data = json.data(using: .utf8) {
do {
let _ = try JSONSerialization.jsonObject(with: data)
print("Valid JSON!")
} catch {
print("Invalid JSON: \(error)")
}
}
const jsonString = '{"name":"Alice","age":30}';
try {
const obj = JSON.parse(jsonString);
console.log("Valid JSON:", obj);
} catch (e) {
console.error("Invalid JSON!", e.message);
}
SELECT '{"name":"Alice","age":30}'::jsonb; -- Will error if not valid JSON
SELECT JSON_VALID('{"name":"Alice","age":30}');
$json = '{"name":"Alice","age":30}'
try {
$obj = $json | ConvertFrom-Json
Write-Output "Valid JSON!"
} catch {
Write-Output "Invalid JSON: $($_.Exception.Message)"
}
use JSON;
my $str = '{"name":"Alice","age":30}';
eval { decode_json($str) };
print $@ ? "Invalid JSON: $@" : "Valid JSON!";
import 'dart:convert';
void main() {
const jsonString = '{"name":"Alice","age":30}';
try {
final obj = jsonDecode(jsonString);
print('Valid JSON: $obj');
} catch (e) {
print('Invalid JSON: $e');
}
}
json = ~s({"name":"Alice","age":30})
case Jason.decode(json) do
{:ok, _} -> IO.puts("Valid JSON!")
{:error, err} -> IO.puts("Invalid JSON: #{err}")
end
import play.api.libs.json._
object Main extends App {
val str = """{"name":"Alice","age":30}"""
try {
val json = Json.parse(str)
println("Valid JSON!")
} catch {
case e: Exception => println("Invalid JSON: " + e.getMessage)
}
}
ఈ టూల్ గురించి
ఈ సాధనం ఇట్సెల్ఫ్ టూల్స్ జట్టు అభివృద్ధి చేసింది, ప్రపంచవ్యాప్తంగా మిల్లియన్ల మందికి ఉపయోగపడే వేగవంతమైన, గోప్యతా-మొదటి ఆన్లైన్ ఉపకరణాల వైవిధ్యాన్ని సృష్టించిన వారు. సరళత, వేగం మరియు నమ్మకదీయతను ప్రాథమ్యంగా కొన్ని బ్రౌజర్ ఆధారిత సాధనాలను తయారు చేసిన అనుభవంతో, మేము డెవలపర్-కేంద్రీకృత అప్లికేషన్లకు విస్తరించాము—ఇలాంటి టెక్నికల్ పనులను ప్రోగ్రామర్లు, విశ్లేషకులు మరియు డిజిటల్ నిపుణులు కోసం సులభతరం చేయడానికి రూపొందించినవి.