Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/Seldaek/jsonlint
JSON Lint for PHP
https://github.com/Seldaek/jsonlint
Last synced: 3 months ago
JSON representation
JSON Lint for PHP
- Host: GitHub
- URL: https://github.com/Seldaek/jsonlint
- Owner: Seldaek
- License: mit
- Created: 2011-12-13T17:07:43.000Z (about 13 years ago)
- Default Branch: main
- Last Pushed: 2024-08-28T08:46:26.000Z (5 months ago)
- Last Synced: 2024-10-29T15:01:35.363Z (3 months ago)
- Language: PHP
- Homepage:
- Size: 164 KB
- Stars: 1,321
- Watchers: 25
- Forks: 57
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Funding: .github/FUNDING.yml
- License: LICENSE
- Security: .github/SECURITY.md
Awesome Lists containing this project
- awesome-php - JSON Lint - A JSON lint utility. (Table of Contents / JSON)
- awesome-json - JSON Lint - PHP linter. (PHP) (Linters)
- awesome-php-cn - JSON Lint - 一个JSON线头效用. (目录 / JSON)
- awesome-projects - JSON Lint - A JSON lint utility. (PHP / JSON)
- awesome-php - JSON Lint - A JSON lint utility. (Table of Contents / JSON)
README
JSON Lint
=========[![Build Status](https://github.com/Seldaek/jsonlint/actions/workflows/continuous-integration.yml/badge.svg)](https://github.com/Seldaek/jsonlint/actions/workflows/continuous-integration.yml)
Usage
-----```php
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_CONFLICTS` throws an exception on duplicate keys.
- `JsonParser::ALLOW_DUPLICATE_KEYS` collects duplicate keys. e.g. if you have two `foo` keys they will end up as `foo` and `foo.2`.
- `JsonParser::PARSE_TO_ASSOC` parses to associative arrays instead of stdClass objects.
- `JsonParser::ALLOW_COMMENTS` parses while allowing (and ignoring) inline `//` and multiline `/* */` comments in the JSON document.
- `JsonParser::ALLOW_DUPLICATE_KEYS_TO_ARRAY` collects duplicate keys. e.g. if you have two `foo` keys the `foo` key will become an object (or array in assoc mode) with all `foo` values accessible as an array in `$result->foo->__duplicates__` (or `$result['foo']['__duplicates__']` in assoc mode).Example:
```php
$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](https://github.com/composer/composer/blob/56edd53046fd697d32b2fd2fbaf45af5d7951671/src/Composer/Json/JsonFile.php#L283-L318):Installation
------------For a quick install with Composer use:
```bash
composer require seld/jsonlint
```JSON Lint can easily be used within another app if you have a
[PSR-4](https://github.com/php-fig/fig-standards/blob/master/accepted/PSR-4-autoloader.md)
autoloader, or it can be installed through [Composer](https://getcomposer.org/)
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](https://github.com/Seldaek/jsonlint/issues)
Author
------Jordi Boggiano - -
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](https://github.com/zaach/jsonlint) library.