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 :

Récupérer des données PHP au format json dans une vue MVC


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
    Étudiant
    Inscrit en
    Octobre 2018
    Messages
    92
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Côte d'Ivoire

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Octobre 2018
    Messages : 92
    Par défaut Récupérer des données PHP au format json dans une vue MVC
    Bonjour Tout le monde , j'ai besoin de votre aide.
    j'ai un tableau PHP que je dois récupérer dans ma vue avec ajax en MVC.
    mon code ajax
    Code javascript : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    var ajax_request = new XMLHttpRequest();
    	ajax_request.open('POST', '/categories/index/' + page + '/' + query);
    	ajax_request.send();
    	ajax_request.onreadystatechange = function () {
    		if (ajax_request.readyState == 4 && ajax_request.status == 200) {
    			var response = JSON.parse(ajax_request.responseText);
    			console.log(response);	
    			//var response = eval(ajax_request);
    			$('#post_data').html(response.data);
    			$('#total_data').html(response.total_data);
    			$('#pagination').html(response.pagination);
     
    		}
    	}
    mon tableau à retourner (traitement.php)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    $output = array(
                'data'              =>    $html,
                'pagination'        =>    $pagination_html,
                'total_data'        =>    $total_data
            );
    	// $this->renderAdmin(url,[donnees], templete)
            $this->render('/categories/index', ['output' => json_encode($output), 'templete');
    Mon problème : je n'arrive pas à recevoir les données au format json pour pouvoir les recupérer comme plus haut (retour ajax)

    j'ai fait une deuxieme methode
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     public function send()
        {
            echo json_encode($this->output);
        }
    $output = array(
                'data'              =>    $html,
                'pagination'        =>    $pagination_html,
                'total_data'        =>    $total_data
            );
            $this->output = $output;
            $this->render('/categories/index', ['output' => $this->send()], 'templete');
    ça ne marche pas.

  2. #2
    Membre Expert
    Profil pro
    Inscrit en
    Mai 2006
    Messages
    721
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Mai 2006
    Messages : 721
    Par défaut
    Regardez avec les outils de votre navigateur s'il y a des messages d'erreurs ou des choses intéressantes dans la console JS.
    Accessoirement, assurez-vous que toutes les variables utilisées dans ce code ont une valeur, vous faites déjà des console.log donc vous pouvez afficher tout cela dans une fenêtre de debug.

  3. #3
    Membre confirmé
    Homme Profil pro
    Étudiant
    Inscrit en
    Octobre 2018
    Messages
    92
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Côte d'Ivoire

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Octobre 2018
    Messages : 92
    Par défaut
    Merci binarygirl,
    je m'excuse pour mon message incomplet :
    console.log(response) donne comme erreur
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    VM54:1 Uncaught SyntaxError: Unexpected token '<', "<!DOCTYPE "... is not valid JSON
        at JSON.parse (<anonymous>)
        at ajax_request.onreadystatechange (categorie.js:458:24)

  4. #4
    Membre Expert
    Profil pro
    Inscrit en
    Mai 2006
    Messages
    721
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Mai 2006
    Messages : 721
    Par défaut
    Je ne sais pas si c'est complet mais c'est déjà un indice très instructif: au lieu de récupérer un flux JSON en fait c'est de l'HTML qui est retourné.
    Donc ça peut être l'URL qui est mauvaise => affichez le résultat de la concaténation pour voir.

    Vous pouvez parfaitement faire console.log pour du débug de JS, et afficher vos variables, etc

    Essayez d'afficher le message HTML complet et le HTTP status code, ça vous dira déjà comment le serveur a interprété votre requête.
    Il est aussi possible que la requête soit mauvaise donc le serveur ne peut pas la traiter.

    Sinon, essayez de reconstituer un exemple partir de ce tuto: https://zetcode.com/javascript/xmlhttprequest/
    et de l'adapter à votre besoin.

    Évidemment, vérifiez que l'endpoint que vous appelez renvoie bien du JSON comme il faut, j'imagine que oui mais à tester.

    Prévoyez aussi un peu de gestion d'erreur dans votre code JS, afin d'avoir plus de visibilité sur les problèmes qui peuvent survenir.

  5. #5
    Membre confirmé
    Homme Profil pro
    Étudiant
    Inscrit en
    Octobre 2018
    Messages
    92
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Côte d'Ivoire

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Octobre 2018
    Messages : 92
    Par défaut
    Toutes mes excuses pour la réponse très tardive
    Essayez d'afficher le message HTML complet et le HTTP status code, ça vous dira déjà comment le serveur a interprété votre requête.
    Il est aussi possible que la requête soit mauvaise donc le serveur ne peut pas la traiter.
    Le serveur traite la requete. Je l'ai fait sans ajax. c-a-d seulement html/php et ça marche.
    Prévoyez aussi un peu de gestion d'erreur dans votre code JS, afin d'avoir plus de visibilité sur les problèmes qui peuvent survenir.
    Merci pour votre conseil

  6. #6
    Expert confirmé Avatar de Toufik83
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Janvier 2012
    Messages
    2 510
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : Maroc

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

    Informations forums :
    Inscription : Janvier 2012
    Messages : 2 510
    Par défaut
    Bonjour,

    Apparemment le retour est toute une page HTML avec <!DOCTYPE ....> et pas du JSON valide, donc une erreur d'ajax.

    En MVC, un contrôleur fait appelle à une Méthode (action), et cette dernière fait appelle a une VUE (HTML), or ce que vous voulez récupérer c'est du JSON au format valide.

    Vous devriez donc supprimer la ligne
    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    $this->render('/categories/index', ['output' => $this->send()], 'templete');
    pour empêcher la méthode d'appeler la VUE correspondante et la remplacer directement par $this->send();

Discussions similaires

  1. Réponses: 0
    Dernier message: 12/12/2020, 01h17
  2. Récupération de données en SQL et tri dans une liste
    Par skurty dans le forum Débuter avec Java
    Réponses: 3
    Dernier message: 24/03/2010, 23h55
  3. Réponses: 3
    Dernier message: 28/01/2010, 10h08
  4. [MySQL] Problème de récupération de données
    Par guillaumeIOB dans le forum PHP & Base de données
    Réponses: 11
    Dernier message: 05/04/2006, 15h13
  5. Problème de récupérations de données dans une table mysql
    Par Helpine dans le forum SQL Procédural
    Réponses: 3
    Dernier message: 09/03/2006, 19h07

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