Jsonlint
JSON Lint for PHP
Install / Use
/learn @Seldaek/JsonlintREADME
JSON Lint
Usage
use Seld\JsonLint\JsonParser;
$parser = new JsonParser();
// returns null if it's valid json, or a ParsingException object.
$parser->lint($json);
// Call getMessage() on the exception object to get
// a well formatted error message error like this
// Parse error on line 2:
// ... "key": "value" "numbers": [1, 2, 3]
// ----------------------^
// Expected one of: 'EOF', '}', ':', ',', ']'
// Call getDetails() on the exception to get more info.
// returns parsed json, like json_decode() does, but slower, throws
// exceptions on failure.
$parser->parse($json);
You can also pass additional flags to JsonParser::lint/parse that tweak the functionality:
JsonParser::DETECT_KEY_CONFLICTSthrows an exception on duplicate keys.JsonParser::ALLOW_DUPLICATE_KEYScollects duplicate keys. e.g. if you have twofookeys they will end up asfooandfoo.2.JsonParser::PARSE_TO_ASSOCparses to associative arrays instead of stdClass objects.JsonParser::ALLOW_COMMENTSparses while allowing (and ignoring) inline//and multiline/* */comments in the JSON document.JsonParser::ALLOW_DUPLICATE_KEYS_TO_ARRAYcollects duplicate keys. e.g. if you have twofookeys thefookey will become an object (or array in assoc mode) with allfoovalues accessible as an array in$result->foo->__duplicates__(or$result['foo']['__duplicates__']in assoc mode).
Example:
$parser = new JsonParser;
try {
$parser->parse(file_get_contents($jsonFile), JsonParser::DETECT_KEY_CONFLICTS);
} catch (DuplicateKeyException $e) {
$details = $e->getDetails();
echo 'Key '.$details['key'].' is a duplicate in '.$jsonFile.' at line '.$details['line'];
}
Note: This library is meant to parse JSON while providing good error messages on failure. There is no way it can be as fast as php native
json_decode().It is recommended to parse with
json_decode, and when it fails parse again with seld/jsonlint to get a proper error message back to the user. See for example how Composer uses this library:
Installation
For a quick install with Composer use:
composer require seld/jsonlint
JSON Lint can easily be used within another app if you have a PSR-4 autoloader, or it can be installed through Composer for use as a CLI util. Once installed via Composer you can run the following command to lint a json file or URL:
$ bin/jsonlint file.json
Requirements
- PHP 5.3+
- [optional] PHPUnit 3.5+ to execute the test suite (phpunit --version)
Submitting bugs and feature requests
Bugs and feature request are tracked on GitHub
Author
Jordi Boggiano - j.boggiano@seld.be - http://twitter.com/seldaek
License
JSON Lint is licensed under the MIT License - see the LICENSE file for details
Acknowledgements
This library is a port of the JavaScript jsonlint library.
Related Skills
node-connect
343.3kDiagnose OpenClaw node connection and pairing failures for Android, iOS, and macOS companion apps
frontend-design
92.1kCreate distinctive, production-grade frontend interfaces with high design quality. Use this skill when the user asks to build web components, pages, or applications. Generates creative, polished code that avoids generic AI aesthetics.
openai-whisper-api
343.3kTranscribe audio via OpenAI Audio Transcriptions API (Whisper).
qqbot-media
343.3kQQBot 富媒体收发能力。使用 <qqmedia> 标签,系统根据文件扩展名自动识别类型(图片/语音/视频/文件)。
