Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/webfiori/json

A JSON helper classes for creating JSON strings in PHP.
https://github.com/webfiori/json

apis hacktoberfest json json-parser php php-library webfiori-framework

Last synced: 2 months ago
JSON representation

A JSON helper classes for creating JSON strings in PHP.

Awesome Lists containing this project

README

        

# WebFiori Json

A helper class library for creating JSON or JSONx strings in PHP. It can be used to create well-formatted json strings from any variable type (strings, numbers, boolean arrays and even objects).














# Content
* [What is JSON?](what-is-json)
* [Features](#features)
* [Supported PHP Versions](#supported-php-versions)
* [Installation](#installation)
* [Code Samples](#code-samples)
* [Basic Usage](#basic-usage)
* [Example](#example)
* [Converting Properties Case](#converting-properties-case)
* [Reading From Files](#reading-from-files)
* [Working With Objects](#working-with-objects)
* [Decoding JSON String](#decoding-json-string)
* [Storing Output](#storing-output)
* [Working With Arrays](#working-with-arrays)
* [JSONx](#jsonx]

## What is JSON?

According to [json.org](https://www.json.org/json-en.html), JSON is a data exchange format which is based partially on JavaScript. It is easy for humans to read and for machines to understand. JSON data is represented as pairs of keys and values.

## Features
* Support fo creating well formatted JSON.
* Support for creating [JSONx](https://www.ibm.com/docs/en/datapower-gateways/10.0.1?topic=20-jsonx).
* Ability to decode JSON strings and convert them to `Json` objects.
* Ability to read JSON files and map JSON values to PHP data types.
* Ability to manipulate JSON properties as needed.

## Supported PHP Versions
| Build Status |
|:-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------:|
| |
| |
| |
| |
| |
| |
| |
| |
| |

## Installation
If you are using composer to manage your dependencies, then it is possible to install the library by including the entry `"webfiori/jsonx":"*"` in the `require` section of your `composer.json` file to install the latest release.

Another way to include the library is by going to [releases](https://github.com/WebFiori/json/releases) and download the latest release and extract compressed file content and add them to your include directory.

## Basic Usage
The process of using the classes is very simple. What you have to do is the following steps:

* Import (or include) the class [`Json`](https://github.com/WebFiori/json/blob/master/webfiori/json/Json.php).
* Create an instance of the class.
* Add data as needed.
* Output the object using `echo` command or any similar one.

For more information and advanced use cases, check [here](https://webfiori.com/learn/webfiori-json).

### Example
The following code shows a very simple usage example.

```php
//load the class "Json"
require_once 'Json.php';
use webfiori\json\Json;

//initialize an object of the class Json
$j = new Json();

//add a number attribute
$j->addNumber('my-number', 34);

//add a boolean with 'false' as its value.
$j->addBoolean('my-boolean', false);

//add a string
$j->addString('a-string', 'Hello, I\'m Json! I like "JSON". ');

header('content-type:application/json');
/*
send back the generated json string.
The output of the code will be like that:
{
"my-number":34,
"my-boolean":false,
"my-number":"Hello, I'm Json! I like \"json\". ",
}
*/
echo $j;
```

Following example shows how data can be added directly using the constructure.

``` php
$jsonObj = new Json([
'first-name' => 'Ibrahim',
'last-name' => 'BinAlshikh',
'age' => 26,
'is-married' => true,
'mobile-number' => null
]);
```

The JSON output of this code will be the following:

``` json
{
"first-name":"Ibrahim",
"last-name":"BinAlshikh",
"age":26,
"is-married":true,
"mobile-number":null
}
```