IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

PHP & Base de données Discussion :

De Php,Mysql vers JSON ? [MySQL]


Sujet :

PHP & Base de données

  1. #1
    Candidat au Club
    Femme Profil pro
    Développeur Web
    Inscrit en
    Juin 2014
    Messages
    5
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2014
    Messages : 5
    Points : 3
    Points
    3
    Par défaut De Php,Mysql vers JSON ?
    Bonjour,
    J'essaie de récupérer des données d'un table d'une base Mysql, et de passer ce résultat en json.
    Cependant je rencontre quelques difficultés.

    Le code que j'utilise est le suivant :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    <?php
     
    // Create connection
    $con=mysqli_connect("localhost","user_test","#5teSt_pw=bdd","ios_bdd");
     
    // Check connection
    if (mysqli_connect_errno())
    {
      echo "Failed to connect to MySQL: " . mysqli_connect_error();
    }
     
    // This SQL statement selects ALL from the table
    $sql = "SELECT * FROM tab_posts";
     
    // Check if there are results
    if ($result = mysqli_query($con, $sql))
    {
        // If so, then create a results array and a temporary one
        // to hold the data
        $resultArray = array();
        $tempArray = array();
     
        // Loop through each row in the result set
        while($row = $result->fetch_object())
        {
            // Add each row into our results array
            $tempArray = $row;
            array_push($resultArray, $tempArray);
        }
     
        // Finally, encode the array to JSON and output the results
        echo json_encode($resultArray);
        var_dump($resultArray);
    }
     
    // Close connections
    mysqli_close($result);
    mysqli_close($con);
    ?>

    Ce qu il se passe, c est que rien ne s'affiche.

    Et le var_dump m'affiche :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    array(2) { [0]=> object(stdClass)#3 (4) { ["id"]=> string(1) "1" ["titre"]=> string(18) "Mon premier post !" ["corps"]=> string(98) "Bonjour à tous! Ceci est mon premier post que je tente de récupérer dans une base mysql, en local." ["date"]=> string(10) "2014-06-21" } [1]=> object(stdClass)#4 (4) { ["id"]=> string(1) "2" ["titre"]=> string(14) "Remplissage =)" ["corps"]=> string(93) "Le remlplissage de la base de donnée avec des valeurs test, avant de les récuperer sur l'ios." ["date"]=> string(10) "2014-06-21" } }

    Si qqun pouvait m'aider à comprendre ce qui ne va pas je lui en serait tres reconnaissante.

    Merci


    <config>Mac OS X (10.9.3) / Chrome 35.0.1916.153</config>

  2. #2
    Membre expert
    Avatar de Dendrite
    Femme Profil pro
    Développeuse informatique
    Inscrit en
    Juin 2008
    Messages
    2 129
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 58
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeuse informatique
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Juin 2008
    Messages : 2 129
    Points : 3 627
    Points
    3 627
    Billets dans le blog
    8
    Par défaut
    Tu es sûre que json_encode accepte un objet en paramètre ?
    http://php.net/manual/fr/function.json-encode.php


    Essaie de remplacer fetch_object par fetch_assoc
    PDO, une soupe et au lit !
    Partir de la fin est un bon moyen de retrouver son chemin. Bibi - 2020

  3. #3
    Candidat au Club
    Femme Profil pro
    Développeur Web
    Inscrit en
    Juin 2014
    Messages
    5
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2014
    Messages : 5
    Points : 3
    Points
    3
    Par défaut
    He bien je ne suis pas "sûre", mais ce code est extrait d'un "tuto de mars 2014", et il semblerai qu il soit censé fonctionné.
    En essayant avec un fetch_assoc(), j'ai le même problème.

  4. #4
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Points : 44 155
    Points
    44 155
    Par défaut
    Ce code fonctionne chez moi.
    Le retour de ton var_dump ne montre rien d'anormal.
    Je ne vois donc pas de raison que le echo n'affiche rien (si c'est bien ça ton problème).

    Tu n'as rien avant ce code ?
    Tu as regardé dans le source HTML du navigateur ?
    Tu peux essayer de placer des echo avant et dans la boucle pour voir.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  5. #5
    Candidat au Club
    Femme Profil pro
    Développeur Web
    Inscrit en
    Juin 2014
    Messages
    5
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2014
    Messages : 5
    Points : 3
    Points
    3
    Par défaut
    En effet je n'ai rien avant ce code.
    Et les tests echo dans la boucles ne sont pas concluant non plus.
    Rien ne s'affiche et rien dans le code source de la page.

    Si c code fonctionne ailleurs (chez vous) cela pourrai venir de ma configuration apache, php mysql ?

  6. #6
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Points : 44 155
    Points
    44 155
    Par défaut
    Tu veux dire que si tu fais
    tu n'as rien.

    Mais que ton var_dump() lui apparait ?
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  7. #7
    Candidat au Club
    Femme Profil pro
    Développeur Web
    Inscrit en
    Juin 2014
    Messages
    5
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2014
    Messages : 5
    Points : 3
    Points
    3
    Par défaut
    Non pardon, je me suis mal exprimé.

    Seulement les echo de json_encode() ne m'affiche rien et le var_dump apparait.
    sinon les echo fonctionnent bien.

    Et je viens de faire un test avec:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    $jstest = array('a'=>0,'b'=>1,'c'=>2,'d'=>3);
        echo json_encode($jstest);
    et ca m'affiche bien :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    {"a":0,"b":1,"c":2,"d":3}
    Je n'arrive just pas à afficher le contenu de ma requete sql en json, je ne comprends pas pourquoi .


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    echo 'json encode :<br>' . json_encode($resultArray); 
    echo '<br>var dump:<br>'; 
    var_dump($resultArray); 
    echo '<br>var export:<br>'; 
    var_export($resultArray);
    Le code précédent m'affiche :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    json encode : 
     
    var dump: 
    array(2) { [0]=> array(4) { ["id"]=> string(1) "1" ["titre"]=> string(18) "Mon premier post !" ["corps"]=> string(98) "Bonjour à tous! Ceci est mon premier post que je tente de récupérer dans une base mysql, en local." ["date"]=> string(10) "2014-06-21" } [1]=> array(4) { ["id"]=> string(1) "2" ["titre"]=> string(14) "Remplissage =)" ["corps"]=> string(93) "Le remlplissage de la base de donnée avec des valeurs test, avant de les récuperer sur l'ios." ["date"]=> string(10) "2014-06-21" } } 
    var export: 
    array ( 0 => array ( 'id' => '1', 'titre' => 'Mon premier post !', 'corps' => 'Bonjour à tous! Ceci est mon premier post que je tente de récupérer dans une base mysql, en local.', 'date' => '2014-06-21', ), 1 => array ( 'id' => '2', 'titre' => 'Remplissage =)', 'corps' => 'Le remlplissage de la base de donnée avec des valeurs test, avant de les récuperer sur l\'ios.', 'date' => '2014-06-21', ), )

  8. #8
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Points : 44 155
    Points
    44 155
    Par défaut
    Je comprends mieux, j'avais mal lu ton test.
    Ajoute l'encodage à ta connexion :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $con->set_charset("utf8")
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  9. #9
    Candidat au Club
    Femme Profil pro
    Développeur Web
    Inscrit en
    Juin 2014
    Messages
    5
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2014
    Messages : 5
    Points : 3
    Points
    3
    Par défaut
    j'ai donc ajouter :

    <code>$con->set_charset("utf8");</code>
    et ca fonctionne.

    Je vous remercie pr votre aide.

    Et merci bcp Sabotage.

    Une petite chose encore. Voici le rendu bien présenté que ca devrai avoir :



    et moi, ca s affiche sur 2 lignes comme ceux-ci:

    [{"id":"1","titre":"Mon premier post","corps":"Contenu de mon premier post\u00a7\r\nEn base de donn\u00e9e mysql.","date":"2014-06-21"},{"id":"2","titre":"Remplissage","corps":"Deuxieme post. Remplissage pr recuperation json et recup vers ios.","date":"2014-06-21"}]

    Est il possible de travailler la form ?

  10. #10
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Points : 44 155
    Points
    44 155
    Par défaut
    Json sert à transmettre des données, la présentation n'a pas d'importance.

    Si tu veux vraiment que ton navigateur le présente, tu peux ajouter
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    header('Content-Type: application/json');
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. [MySQL] migration de Fonction récursive PHP/MYSQL vers PHP5 CodeIgniter /mysql
    Par Hasret dans le forum PHP & Base de données
    Réponses: 0
    Dernier message: 13/03/2013, 19h32
  2. de php/mysql vers php/firebird
    Par omar24 dans le forum PHP & Base de données
    Réponses: 1
    Dernier message: 22/02/2011, 11h46
  3. [PHP 5.3] PHP & MySql vers un fichier Excel
    Par hubux dans le forum Langage
    Réponses: 4
    Dernier message: 27/07/2010, 14h39
  4. de php/Mysql vers php/access
    Par houdta dans le forum Langage
    Réponses: 1
    Dernier message: 21/08/2009, 14h14
  5. PHP-mysql -> vers appli GTK ou autre
    Par mao-40 dans le forum Linux
    Réponses: 2
    Dernier message: 06/12/2008, 14h11

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo