Il formato di dati Json è stato creato per facilitare il trasferimento di dati strutturati tra client e server.
Per convertire un array o un oggetto in Json, c'è una funzione json_encode
in PHP:
$user = ['nome' => 'Jan','cognome' => 'Barasek','ruolo' => ['Admin','moderatore',],];echo json_encode($user);
Genererà:
{"name":"Jan","surname":"Barasek","role":["admin","moderator"]}
La funzione json_encode()
può anche convertire altri tipi di dati. Per esempio, possiamo inserire direttamente integer
(intero), string
(stringa) e così via.
Nella configurazione predefinita, json è generato come una lunga stringa. Questo per il motivo di occupare meno spazio possibile.
Se hai bisogno di una migliore leggibilità, passa semplicemente la costante JSON_PRETTY_PRINT
come secondo parametro:
echo json_encode($users, JSON_PRETTY_PRINT);
Genererà:
{"nome": "Jan","cognome": "Barasek","ruolo": ["Admin","moderatore"]}
La normale formattazione di json via PHP non ha impostazioni aggiuntive e dobbiamo accontentarci solo di questo output. Per esempio, se vogliamo far rientrare le tabulazioni invece degli spazi (o modificare le regole di generazione in qualsiasi modo), dobbiamo programmarlo noi stessi.
Questa funzione può già fare la formattazione di base e dobbiamo solo modificarla:
function prettyJsonPrint(string $json): string{$result = '';$level = 0;$in_quotes = false;$in_escape = false;$ends_line_level = NULL;$json_length = strlen($json);for ($i = 0; $i < $json_length; $i++) {$char = $json[$i];$new_line_level = NULL;$post = '';if ($ends_line_level !== NULL) {$new_line_level = $ends_line_level;$ends_line_level = NULL;}if ($in_escape) {$in_escape = false;} else if ($char === '"') {$in_quotes = !$in_quotes;} else if (!$in_quotes) {switch ($char) {case '}':case ']':$level--;$ends_line_level = NULL;$new_line_level = $level;break;case '{':case '[':$level++;case ',':$ends_line_level = $level;break;case ':':$post = '';break;case "":case "\t":case "\n":case "\r":$char = '';$ends_line_level = $new_line_level;$new_line_level = NULL;break;}} else if ($char === '\\') {$in_escape = true;}if ($new_line_level !== NULL) {$result .= "\n" . str_repeat("\t", $new_line_level);}$result .= $char . $post;}return $result;}
Fonte: https://stackoverflow.com/questions/6054033/pretty…
Per esempio, input:
{"chiave1":[1,2,3],"chiave2":"valore"}
Formattato come:
{"chiave1": [1,2,3],"chiave2": "valore"}
Che è molto più facile da leggere (a causa dell'indentazione coerente di ogni elemento).
A volte può essere utile colorare le chiavi, i dati stessi e i singoli elementi di formattazione (specialmente le parentesi di chiusura).
Per esempio, input:
{"accesso": {"token": {"emesso_a": "2008-08-16T14:10:31.309353", "scade": "2008-08-17T14:10:31Z", "id": "MIICQgYJKoZIhvcIegeyJpc3N1ZWRfYXQiOiAi"}, "serviceCatalog": [], "utente": {"nome utente": "ajay", "collegamenti ai ruoli": [], "id": "16452ca89", "ruoli": [], "nome": "ajay"}}}
Formattato come:
{
"access": {
"token": {
"issued_at": "2008-08-16T14:10:31.309353",
"expires": "2008-08-17T14:10:31Z",
"id": "MIICQgYJKoZIhvcIegeyJpc3N1ZWRfYXQiOiAi"
Si prega di non utilizzare il sistema di sicurezza.
"serviceCatalog": [
[], ],
"user": {
"username": "ajay",
"roles_links": [
[], ],
: "16452ca89",
"roles": [
[*], ],
"name": "ajay"
}
}
}
Questo può essere implementato dalla seguente funzione:
function jsonColorFormater(string $json, string $indentation = "\t"): string{$crl = 0;$ss = false;$buffer = '';for ($c = 0; $c < strlen($json); $c++) {if ($json[$c] == '}' || $json[$c] == ']') {$crl--;$buffer .= "\n" . str_repeat($indentation, $crl);}if ($json[$c] == '"' && (@$json[$c - 1] == ',' || @$json[$c - 2] == ',')) {$buffer .= "\n" . str_repeat($indentation, $crl);}if ($json[$c] == '"' && !$ss) {$buffer .= '<span style="color:'.((@$json[$c - 1] == ':' || @$json[$c - 2] == ':') ? '#35D' : '#C22').';">';}$buffer .= $json[$c];if ($json[$c] == '"' && $ss) $buffer .= '</span>';if ($json[$c] == '"') $ss = !$ss;if ($json[$c] == '{' || $json[$c] == '[') {$crl++;$buffer .= "\n". str_repeat($indentation, $crl);}}// Restituisce il sorgente HTMLreturn '<pre>' . $buffer . '</pre>';}// Basta chiamare questo e restituire l'output formattato// echo jsonColorFormater($data, ' ');
Caratteristica presa e riscritta radicalmente da: https://stackoverflow.com/a/20953262/6777550
Questo può essere implementato con la funzione json_decode(), che crea una struttura di dati da Json con cui dobbiamo lavorare come un oggetto:
$json = '{"nome": "Jan", "cognome": "Barasek", "ruolo":["admin", "moderatore"]}';$decode = json_decode($json);echo $decode->name; // Restituisce 'Jan'// echo $decode->role;//// Questo non è possibile perché il ruolo della proprietà// contiene un array, dobbiamo iterare.echo '<ul>';foreach ($decode->role as $role) {echo '<li>' . $role . '</li>'; // Elenca consecutivamente i ruoli dietro i proiettili}echo '</ul>';
Per esempio, nella libreria jQuery, una stringa json può essere analizzata in un oggetto molto facilmente:
var json = '{"nome": "Jan", "cognome": "Barasek", "ruolo":["admin", "moderatore"]}';var parser = $.parseJSON(json);document.write('Nome:' + parser.name);console.log(parser); // Stampa l'intero oggetto sulla console per il debug
In javascript, in generale, qualsiasi json è un oggetto javascript valido con cui si può lavorare direttamente e accedere alle sue proprietà.
Jan Barášek Více o autorovi
Autor článku pracuje jako seniorní vývojář a software architekt v Praze. Navrhuje a spravuje velké webové aplikace, které znáte a používáte. Od roku 2009 nabral bohaté zkušenosti, které tímto webem předává dál.
Rád vám pomůžu:
Články píše Jan Barášek © 2009-2025 | Kontakt | Mapa webu
Status | Aktualizováno: ... | it