Curs Php-mysql

Transformare obiect JSON in Array asociativ
 

Acest tutorial arata cum se preia in PHP datele dintr-un sir cu obiect JSON, folosind json_decode().
Obiectul (sirul JSON) poate fi preluat dintr-o sursa externa. De exemplu, de la o adresa URL (cu file_get_contents(), sau cURL) care returneaza un sir cu date in obiect JSON, sau dintr-un fisier text de pe server, sau dintr-o baza de date.


Sa lucram cu un exemplu simplu; un obiect JSON salvat intr-un fisier text pe server.
Fisierul, denumit "sitedata.txt" contine acest sir, un obiect JSON simplu, cu 3 proprietati (url, category, nr_pages):
{"url": "https://coursesweb.net/", "category": "Web Development", "nr_pages": 400}
Folosim file_get_contents() pentru a citi datele (sirul) din fisierul text, apoi, cu json_decode() se transforma sirul intr-un obiect PHP.
<?php
$file = 'sitedata.txt'; // adresa /numele fisierului

// verifica daca fisierul exista
if(file_exists($file)) {
 $filedata = file_get_contents($file);

 /* Sau, se poate adauga direct acest sir:
 $filedata = '{"url": "https://coursesweb.net/", "category": "Web Development", "nr_pages": 400}';
 */

 // transforma sirul in obiect al clasei stdClass
 $objson = json_decode($filedata, true);

 // parcurge obiectul si afiseaza fiecare proprietate si valoarea ei
 foreach($objson AS $prop => $val) {
 echo '<br/>'. $prop .' - '. $val;
 }
}
else echo $file .' nu exista';
Afiseaza:
url - https://coursesweb.net/
category - Web Development
nr_pages - 400

Preluare date din obiect PHP

- Functia json_decode() transforma sirul JSON intr-un Obiect al clasei stdClass. Ca sa obtineti valoarea asociata unei anumite proprietati, se foloseste aceasta sintaxa:
$valoare = $obiect->nume_proprietate;
Sau, daca "nume_proprietate" este intr-o variabila, se foloseste aceasta sintaxa:
$property = 'nume_proprietate';
$valoare = $obiect->{$property};

Iata un alt exemplu;
<?php
// sir cu obiect JSON
$strjson = '{"url": "https://coursesweb.net/", "category": "Web Development", "nr_pages": 400}';

// transforma sirul in obiect al clasei stdClass
$objson = json_decode($strjson);

// preia valoarea unei anumite proprietati
$url = $objson->url;
echo '<br/>'. $url;

// preia valoarea unei proprietati cu numele salvat in variabila
$prop = 'category';
$val = $objson->{$prop};
echo '<br/>'. $val;
Acest cod va afisa:
https://coursesweb.net/
Web Development

Este important ca sirul sa fie un obiect JSON valid, altfel, functia json_decode() va returna False sau Null.

 

Transformare obiect JSON in Array asociativ

Daca vreti sa transformati sirul cu obiect JSON intr-un Array asociativ in PHP, adaugati True ca al doilea argument in json_decode().
Sintaxa:
$arr = json_decode($sir_json, true);
Exemplu:
<?php
// sir cu obiect JSON
$strjson = '{"url": "https://marplo.net/", "category": "Diverse", "nr_pages": 1500}';

// transforma sirul in array asociativ
$arrjson = json_decode($strjson, true);

// Test
var_dump($arrjson);

// preia valoarea unui anumit element
$url = $arrjson['url'];
echo '<br/>'. $url;

// preia valoarea unui element cu numele retinut in variabila
$elm = 'category';
$val = $arrjson[$elm];
echo '<br/>'. $val;
Rezulta:
array(3) { ["url"]=> string(18) "https://marplo.net/" ["category"]=> string(7) "Diverse" ["nr_pages"]=> int(1500) }
http://marplo.net/
Diverse
• Sirul JSON poate sa contina date mai complexe, cu o structura formata din mai multe obiecte si array. In acest caz trebuie sa stiti cum sa lucrati cu Array in PHP.
Iata un exemplu:
<?php
// sir cu obiect JSON, continand inca un obiect, si un Array
$strjson = '{
 "url": "https://marplo.net/",
 "category": {"ct1": "Web Development", "ct2": "Web Programming"},
 "courses": ["PHP-MySQL", "JavaScript", "HTML", "CSS"]
}';

// converteste sirul intr-un array asociativ
$arrjson = json_decode($strjson, true);

// Afiseaza structura array-ului
echo '<pre>';
var_export($arrjson);
echo '</pre>';

// preia prima categorie "ct1", si al doilea element in "courses"
$ct1 = $arrjson['category']['ct1'];
$course2 = $arrjson['courses'][1];

echo $ct1 .'<br/>'. $course2;
Rezulta:
array (
 'url' => 'https://marplo.net/',
 'category' => 
 array (
 'ct1' => 'Web Development',
 'ct2' => 'Web Programming',
 ),
 'courses' => 
 array (
 0 => 'PHP-MySQL',
 1 => 'JavaScript',
 2 => 'HTML',
 3 => 'CSS',
 )
)

Web Development
JavaScript


• Formatul JSON este folosit in special in Aplicatii Web Development, precum Facebook App, Google Apps, Youtube Api.
Daca sirul cu date de la acel Appi nu este un format JSON corect, trebuie sa prelucrati sirul ca sa obtineti formatul JSON valid inainte de a utiliza json_decode().
De exemplu, datele "info" de la Youtube Api sunt intr-un sir cu obiect JSON, dar sirul in intregime nu este format JSON valid:
info = { "title" : "DaOne - povestea noastra (feat. Ewa)", "image" : "http://i.ytimg.com/vi/6UjfTKHQ4vo/default.jpg", "length" : "4", "status" : "serving", "progress_speed" : "", "progress" : "", "ads" : "", "pf" : "http://acef.u.aclst.com/ping.php?video_id=6UjfTKHQ4vo&h=2717", "h" : "a148abf7ef86bab307d50d0d9d6177f0" };
Iata cum se pot prelua datele din acest sir.
<?php
// sir cu date de la Youtube App
$yinfo = 'info = {
 "title" : "DaOne - povestea noastra (feat. Ewa)",
 "image" : "http://i.ytimg.com/vi/6UjfTKHQ4vo/default.jpg",
 "length" : "4",
 "status" : "serving",
 "progress_speed" : "",
 "progress" : "",
 "ads" : "",
 "pf" : "http://acef.u.aclst.com/ping.php?video_id=6UjfTKHQ4vo&h=2717",
 "h" : "a148abf7ef86bab307d50d0d9d6177f0"
};';

/*
 Se poate prelua acest sir de la pagina Youtube Api folosind acest cod:
 $url = 'http://www.youtube-mp3.org/api/itemInfo/?video_id=6UjfTKHQ4vo&adloc=&r={{datetime}}';
 $yinfo = file_get_contents($url);
*/

// preia doar subsirul cu formatul JSON valid
if(preg_match('/{(.*?)}/i', $yinfo, $infojson)) {
 // converteste obiectul JSON in array asociativ
 $arrjson = json_decode($infojson[0], true);

 // afisaza datele de la 'title' si 'image'
 $title = $arrjson['title'];
 $imgsrc = $arrjson['image'];

 echo $title .'<br/>'. $imgsrc;
}

Un Test simplu in fiecare zi

HTML
CSS
JavaScript
PHP-MySQL
Engleza
Spaniola
Care tag e folosit pentru a adauga liste cu definitii in element <dl>?
<dt> <dd> <li>
<dl>
 <dt>HTML</dt>
  <dd> - Hyper Text Markup Language</dd>
  <dd> - Limbaj de cod pentru pagini web</dd>
</dl>
Care proprietate CSS poate sa ascunda un element in pagina, lasand spatiu gol in locul lui?
display position visibility
#id {
  visibility: hidden;
}
Indicati evenimentul declansat cand se apasa clic pe un obiect in pagina.
onclick onmouseover onfocus
document.getElementById("id").onclick = function(){
  alert("http://www.MarPlo.net/");
}
Indicati variabila PHP ce contine datele din $_GET, $_POST si $_COOKIE.
$_SESSION $_GET $_REQUEST
if(isset($_REQUEST["id"])) {
  echo $_REQUEST["id"];
}
Care din urmatoarele cuvinte reprezinta un Verb?
lighting believe path
I believe in my path.
- Eu cred in calea mea.
Care din urmatoarele cuvinte reprezinta un Verb?
creer camino iluminación
creer = a crede; camino = cale /drum; iluminación = iluminare
Preluare date dintr-un sir cu obiect JSON

Last accessed pages

  1. Editare, Modificare XML - E4X (1769)
  2. Tag-urile DIV si SPAN (9642)
  3. Curs de Miracole (2947)
  4. Cursuri si Tutoriale: Engleza, Spaniola, HTML, CSS, Php-Mysql, JavaScript, Ajax (261439)
  5. Deznodamant fericit pentru toate e cert (15)

Popular pages this month

  1. Cursuri si Tutoriale: Engleza, Spaniola, HTML, CSS, Php-Mysql, JavaScript, Ajax (1083)
  2. Curs HTML gratuit Tutoriale HTML5 (887)
  3. Coduri pt culori (626)
  4. Creare si editare pagini HTML (517)
  5. Conditional IF in Limba Engleza - Fraze Conditionale (469)
Chat
Discuta sau lasa un mesaj pt. ceilalti utilizatori
Full screenInchide