Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Are booleans valid JSON

Why do some JSON validators flag a boolean value as invalid JSON, and others as valid? That is, just true or false values (no object).

Valid:

  • http://jsonlint.com/
  • http://codebeautify.org/jsonvalidator

Invalid:

  • https://jsonformatter.curiousconcept.com/
like image 481
user1491636 Avatar asked Sep 06 '16 15:09

user1491636


People also ask

Can you pass boolean in JSON?

Boolean values must be passed without quotes. Boolean is one of the types supported by json: https://www.json.org/json-en.html and the expected values are true or false, without quotes.

Is JSON boolean case sensitive?

JSON is case-sensitive. SQL is case-insensitive, but names in SQL code are implicitly uppercase.

How do I check if JSON is valid?

The simplest way to check if JSON is valid is to load the JSON into a JObject or JArray and then use the IsValid(JToken, JsonSchema) method with the JSON Schema. To get validation error messages, use the IsValid(JToken, JsonSchema, IList<String> ) or Validate(JToken, JsonSchema, ValidationEventHandler) overloads.


1 Answers

The validator you link to validates the JSON string existing of a mere true as invalid according to RFC 4627, which dictates that the root of a JSON string is to be an array or object:

A JSON text is a serialized object or array.

 JSON-text = object / array 

An unwrapped value such as true or "foo" or 42 is not JSON according to that RFC.

The other RFCs it can validate against, RFC 7159 and RFC 8259, deem the above examples valid as it does not constrain a JSON text to objects or arrays, but also allows values:

A JSON value MUST be an object, array, number, or string, or one of the following three literal names:

 false null true 

And because the former (RFC 4627) is obsoleted by the latter two (RFC 7159 respectively 8259), true is a valid JSON string.

like image 100
CodeCaster Avatar answered Sep 22 '22 01:09

CodeCaster