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

AJAX Discussion :

Impossible de décoder un JSON depuis AJAX


Sujet :

AJAX

  1. #1
    Membre confirmé
    Homme Profil pro
    Développeur (aussi appelé "programmateur" ou "magicien")
    Inscrit en
    Octobre 2014
    Messages
    101
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

    Informations professionnelles :
    Activité : Développeur (aussi appelé "programmateur" ou "magicien")
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2014
    Messages : 101
    Par défaut Impossible de décoder un JSON depuis AJAX
    Bonjour,

    Je dois résoudre un problème dans une application web qu'un de mes anciens collègues avait développé. Celui-ci n'étant malheureusement plus là, et mes collègues ne s'y connaissant pas en web (nous n'en faisont quasiment plus), je tente depuis une semaine de débuger la bête, mais n'étant pas un expert, je n'y arrive pas (Pour vous situer j'ai appris avec cette tâche que que sont JQuery, AJAX et JSON ).

    Bref, j'ai tout de même trouvé (non sans peine) l'origine du problème :

    J'ai une requête AJAX qui exécute une fonction PHP. Cette fonction PHP effectue un SELECT dans une base de données, et renvoie celle-ci en JSON (avec json_encode, et le JSON généré est conforme, j'ai vérifié avec un validateur online). Le problème est que la requête AJAX n'arrive pas à décoder celui-ci .

    Voici les sources :

    AJAX :
    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
    $.ajax({
    			url: 'utilisateur/obtenir-liste-utilisateur.php',
    			type: 'GET',
    			data: {
    				type: typeUtilisateur,
    			},
    			contentType:"application/json; charset=utf-8",
    			dataType: 'json',
    			success: function(data){
    				switch(typeUtilisateur){
    			    	case 'client':
    			    		listeClients = data;
    			    		break;
    			    	case 'courtier':
    			    		listeCourtiers = data;
    			    		break;
    			    	default:
    			    		break;
    			    }
     
    				 $( "input.tableau-annonce-" + typeUtilisateur).autocomplete({
    			      source: data
    			    });
               	},
     
               	error : function(result, statut, erreur){
    				alert(erreur);
    				alert(JSON.stringify(result));
    			},
    		});
    PHP:
    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
    // Inclusion des librairies. 
    require_once('../includes/utils.php');
     
    // Connexion à la base de données.
    $connexion = bd_connexion();
     
    // Préparation de la requête.
    $requete = "SELECT * FROM tb_utilisateur WHERE type_utilisateur='" . $_GET['type'] . "'";
     
    // Exécution de la requête.
    $res = bd_requete($connexion, $requete);
     
    $liste_utilisateur;
    $utilisateur_a_ajouter;
     
    while($ligne = mysqli_fetch_assoc($res)){
    	$utilisateur_a_ajouter = $ligne['nom_utilisateur'];
     
    	if(isset($ligne['prenom_utilisateur'])){
    		if(strlen($ligne['prenom_utilisateur']) > 0) {
    			$utilisateur_a_ajouter .= " " . $ligne['prenom_utilisateur'];
    		}
    	}
     
    	$liste_utilisateur[] = $utilisateur_a_ajouter;
    }
     
    bd_ferme($connexion);
     
    // Retourne le résultat du tableau en JSON.
    echo json_encode($liste_utilisateur);
    Le code fonctionnait parfaitement auparavant, je m'explique :
    L'application a été supprimé par erreur, en même temps qu'un ancien nom de domaine. J'ai donc dû réinstaller celle-ci sur le nouveau nom de domaine (j'ai fait un copier-coller des fichiers, et j'ai restauré une copie de la base MySQL). Il est probable que les versions de PHP et des autres choses qui tournent ont changées (j'ai déjà tenté en vain de modifier la version de PHP).

    Il est donc probable que ce soit soit un problème de version, soit une erreur de ma part lorsque j'ai remis en ligne l'application .

    Merci d'avance pour votre aide, car j'avoue que je sèche complètement .

  2. #2
    Modérateur

    Avatar de NoSmoking
    Homme Profil pro
    Inscrit en
    Janvier 2011
    Messages
    17 198
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations forums :
    Inscription : Janvier 2011
    Messages : 17 198
    Par défaut
    Bonjour,
    Le problème est que la requête AJAX n'arrive pas à décoder celui-ci
    qu'entends tu par là, as tu des erreurs (F12 pour voir la console) ?

  3. #3
    Membre confirmé
    Homme Profil pro
    Développeur (aussi appelé "programmateur" ou "magicien")
    Inscrit en
    Octobre 2014
    Messages
    101
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

    Informations professionnelles :
    Activité : Développeur (aussi appelé "programmateur" ou "magicien")
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2014
    Messages : 101
    Par défaut
    Bonjour,

    En effet, j'ai une erreur (que j'ai oublié de préciser ):

    SyntaxError: Unexpected token  in JSON at position 0

    Cette erreur ne s'affiche pas dans la console, elle provient d'un alert à la ligne 27 du code AJAX que j'ai mis dans mon premier message ^^.
    Comme dit également, le JSON renvoyé par la fonction PHP est valide...

  4. #4
    Expert confirmé
    Avatar de mathieu
    Profil pro
    Inscrit en
    Juin 2003
    Messages
    10 640
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 10 640
    Par défaut
    Citation Envoyé par mistercactus Voir le message
    le JSON renvoyé par la fonction PHP est valide
    montrez nous le résultat qui apparait dans la console de développement.

  5. #5
    Expert confirmé
    Avatar de mathieu
    Profil pro
    Inscrit en
    Juin 2003
    Messages
    10 640
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 10 640
    Par défaut
    quand je parlais de la console de développement, je pensais aux détails de la réponse de la requête dans l'onglet "Réseau" :
    https://developer.mozilla.org/fr/doc...equest_details

  6. #6
    Membre confirmé
    Homme Profil pro
    Développeur (aussi appelé "programmateur" ou "magicien")
    Inscrit en
    Octobre 2014
    Messages
    101
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

    Informations professionnelles :
    Activité : Développeur (aussi appelé "programmateur" ou "magicien")
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2014
    Messages : 101
    Par défaut
    D'accord, voici donc les détails pour mon fichier obtenir-liste-utilisateur.php :
    Nom : Capture résultat réseau obtenir-liste-utilisateur.php.PNG
Affichages : 417
Taille : 23,3 Ko

    Et pour le fichier contenant l'ajax (index-php):
    Nom : Capture résultat réseau index.php.jpg
Affichages : 428
Taille : 734,5 Ko

  7. #7
    Expert confirmé
    Avatar de mathieu
    Profil pro
    Inscrit en
    Juin 2003
    Messages
    10 640
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 10 640
    Par défaut
    quand vous cliquez sur la requête HTTP, il y aura un panneau à gauche qui va s'ouvrir et dans un des onglets de ce panneau vous pourrez y voir la réponse.

  8. #8
    Membre confirmé
    Homme Profil pro
    Développeur (aussi appelé "programmateur" ou "magicien")
    Inscrit en
    Octobre 2014
    Messages
    101
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

    Informations professionnelles :
    Activité : Développeur (aussi appelé "programmateur" ou "magicien")
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2014
    Messages : 101
    Par défaut
    Effectivement, la voici :
    Nom : Capture réponse obtenir-liste-utilisateur.PNG
Affichages : 419
Taille : 15,6 Ko

    J'ai, par confidentialité, noirci les données renvoyées (mais celles-ci sont en minuscules, sans accents, sans caractères spéciaux, sans espaces).

  9. #9
    Expert confirmé
    Avatar de mathieu
    Profil pro
    Inscrit en
    Juin 2003
    Messages
    10 640
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 10 640
    Par défaut
    est ce que le point rouge représente un caractère ?
    allez à l'URL utilisateur/obtenir-liste-utilisateur.php?type=... et regardez le code source pour voir s'il y a une espace avant le 1er "["

  10. #10
    Membre confirmé
    Homme Profil pro
    Développeur (aussi appelé "programmateur" ou "magicien")
    Inscrit en
    Octobre 2014
    Messages
    101
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

    Informations professionnelles :
    Activité : Développeur (aussi appelé "programmateur" ou "magicien")
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2014
    Messages : 101
    Par défaut
    Voici ce que j'obtiens (j'ai fait la sélection avec ctrl + a) :
    Nom : Captureréponse.PNG
Affichages : 392
Taille : 1,9 Ko

    Apparemment il n'y a rien...

  11. #11
    Expert confirmé
    Avatar de mathieu
    Profil pro
    Inscrit en
    Juin 2003
    Messages
    10 640
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 10 640
    Par défaut
    désolé je viens de faire le test et en fait s'il y a un BOM au début du fichier, il n'apparait pas dans le code source mais jQuery affiche bien un message d'erreur en refusant d'analyser le JSON.

    essayez d'ouvrir le fichier PHP et faire "enregistrer sous" en choisissant l'option "UTF-8 sans BOM". suivant l'éditeur que vous utilisez, cela peut aussi se trouver dans une option d'affichage et d'édition
    https://fr.wikipedia.org/wiki/Indica...dre_des_octets

  12. #12
    Membre confirmé
    Homme Profil pro
    Développeur (aussi appelé "programmateur" ou "magicien")
    Inscrit en
    Octobre 2014
    Messages
    101
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

    Informations professionnelles :
    Activité : Développeur (aussi appelé "programmateur" ou "magicien")
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2014
    Messages : 101
    Par défaut
    Je l'ai enregistré en UTF 8 sans BOM, mais le point rouge est toujours là...

    Pour info, j'ai vidé le cache et les cookies du navigateur avant.

    EDIT: L'enregistrement a été effectué avec notepad++, et j'ai enregistré les deux fichiers concernés

  13. #13
    Expert confirmé
    Avatar de mathieu
    Profil pro
    Inscrit en
    Juin 2003
    Messages
    10 640
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 10 640
    Par défaut
    Cela peut aussi venir d'un autre fichier inclus.

  14. #14
    Membre confirmé
    Homme Profil pro
    Développeur (aussi appelé "programmateur" ou "magicien")
    Inscrit en
    Octobre 2014
    Messages
    101
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

    Informations professionnelles :
    Activité : Développeur (aussi appelé "programmateur" ou "magicien")
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2014
    Messages : 101
    Par défaut
    En effet, j'inclue depuis mon fichier PHP le fichier utils.php, qui inclue le fichier config.php, qui lui est en UTF8 avec BOM.

    Merci beaucoup pour votre aide !

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

Discussions similaires

  1. Tableau Json depuis Ajax
    Par Invité dans le forum Général JavaScript
    Réponses: 9
    Dernier message: 15/02/2013, 13h40
  2. Réponses: 1
    Dernier message: 10/01/2013, 09h39
  3. [Tomcat] Impossible de démarrer le serveur depuis Eclipse
    Par illmonkey dans le forum Eclipse Java
    Réponses: 12
    Dernier message: 08/03/2006, 13h30

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