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 :

problème avec json_encode [MySQL]


Sujet :

PHP & Base de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Homme Profil pro
    Inscrit en
    Janvier 2003
    Messages
    120
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations forums :
    Inscription : Janvier 2003
    Messages : 120
    Par défaut problème avec json_encode
    j'ai un problème avec la fonction json_encode

    je veux afficher correctement le résultat en JSON pour ne pas avoir ensuite des problèmes de caractères accentués

    je mets donc le header en UTF-8

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    header('content-type: text/html; charset=UTF-8');
    ensuite je mets MYSQL en UTF-8 avant de traiter ma requte
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    $dblink=connect_mysql();
    mysql_set_charset('utf8',$dblink);
    $requete = mysql_query("SELECT ...",$dblink);

    et ensuite je veux afficher le résultat en JSON

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    while($row=mysql_fetch_assoc($sql)) 
    {
     $output[]=$row;
    }
     
    $output[]=$row;
    lorsque je fais :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    print(json_encode($output));
    je récupère alors des \u00e9 a la place des é ...

    et lorsque je n'utilise pas json_encode
    alors mon résultat est propre

    je n'arrive pas à trouver, j'ai vu dans la doc que json_encode ne supporte que le UTF-8 mais justement j'ai tout fait pour cela ...

    avez-vous une idée pour m'aider, je m'arrache les cheveux depuis trois jours

    merci

  2. #2
    Expert confirmé

    Profil pro
    Inscrit en
    Septembre 2010
    Messages
    7 920
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2010
    Messages : 7 920
    Par défaut
    c'est normale

  3. #3
    Membre confirmé
    Homme Profil pro
    Inscrit en
    Janvier 2003
    Messages
    120
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations forums :
    Inscription : Janvier 2003
    Messages : 120
    Par défaut
    Ok mais pourquoi ?

  4. #4
    Expert confirmé

    Profil pro
    Inscrit en
    Septembre 2010
    Messages
    7 920
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2010
    Messages : 7 920
    Par défaut
    Citation Envoyé par aztec Voir le message
    Ok mais pourquoi ?
    par que le json n'utilise que les caracteres assci, fais un json_decode tu verras que y'a pas de problème

  5. #5
    Membre confirmé
    Homme Profil pro
    Inscrit en
    Janvier 2003
    Messages
    120
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations forums :
    Inscription : Janvier 2003
    Messages : 120
    Par défaut
    oui, merci effectivement je peux afficher correctement les caractères dont mon script php avec un json_decode

    mais le problème c'est que je dois encoder en json pour pouvoir ensuite traiter le resultat avec android (en java) ... et si je fais un json_decode, mon traitement android ne fonctionne plus puisque je traite du JSON

    voici mon autre programme de traitement android (désolé, je sais , je suis à la frontière entre deux forums ...)

    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
    // Conversion de la requête en string  
            try{  
            	  BufferedReader reader = new BufferedReader(new InputStreamReader(is,"UTF-8"),8);
            	  StringBuilder sb = new StringBuilder();  
                   String line = null;  
                  while ((line = reader.readLine()) != null) {  
                  sb.append(line + "\n");  
                  }  
                  is.close();  
                  result=sb.toString();  
                }catch(Exception e){  
                  Log.e("log_tag", "Error converting result " + e.toString());  
                  }  
                 // Parse les données JSON  
             try{  
                  JSONArray jArray = new JSONArray(result);  
                  for(int i=0;i<jArray.length();i++){  
                  JSONObject json_data = jArray.getJSONObject(i);  
              // Résultats de la requête  
               returnString += "\n\t" + json_data.getString("Auteur");
               returnString += "," + json_data.getString("Titre");
               returnString += "," + json_data.getString("year");
               }  
                  }catch(JSONException e){  
            Log.e("log_tag", "Error parsing data " + e.toString());  
                 }
           		 return returnString;

  6. #6
    Expert confirmé

    Profil pro
    Inscrit en
    Septembre 2010
    Messages
    7 920
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2010
    Messages : 7 920
    Par défaut
    normalement Andrïd doit gérer le json correctement

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

Discussions similaires

  1. [PHP 5.2] Problème pour décoder avec json_encode()
    Par titou624 dans le forum Langage
    Réponses: 3
    Dernier message: 03/05/2011, 11h56
  2. VC++ Direct3D8, problème avec LPD3DXFONT et LPD3DTEXTURE8
    Par Magus (Dave) dans le forum DirectX
    Réponses: 3
    Dernier message: 03/08/2002, 11h10
  3. Problème avec le type 'Corba::Any_out'
    Par Steven dans le forum CORBA
    Réponses: 2
    Dernier message: 14/07/2002, 18h48
  4. Problème avec la mémoire virtuelle
    Par Anonymous dans le forum CORBA
    Réponses: 13
    Dernier message: 16/04/2002, 16h10

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