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

Langage PHP Discussion :

non-récupération des données d'un formulaire


Sujet :

Langage PHP

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre Expert
    Avatar de laurentSc
    Homme Profil pro
    Webmaster débutant perpétuel !
    Inscrit en
    Octobre 2006
    Messages
    10 493
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Webmaster débutant perpétuel !
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 493
    Billets dans le blog
    1
    Par défaut non-récupération des données d'un formulaire
    Bonsoir,

    je fais un formulaire qui me semble très simple et pourtant pas moyen d'en récupérer les données :

    Code html : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    <form action="action_patient.php" type="post">
    <table>
    <tr><td>Nom : </td><td><input type="text" name="nom" size="20"></td></tr>
    <tr><td>Prénom : </td><td><input type="text" name="prenom" size="20"></td></tr>
    <tr><td></td><td><input type="submit" value="envoyer"></td></tr>
    </table>
    </form>

    action_patient.php
    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
        <?php
     
    $PARAM_hote='----'; // le chemin vers le serveur
    $PARAM_nom_bd='----'; // le nom de votre base de données
    $PARAM_utilisateur='----'; // nom d'utilisateur pour se connecter
    $PARAM_mot_passe='----'; // mot de passe de l'utilisateur pour se connecter
    $connexion = new PDO('mysql:host='.$PARAM_hote.';dbname='.$PARAM_nom_bd, $PARAM_utilisateur, $PARAM_mot_passe);	
    $sql="INSERT INTO `patient` (nom,prenom) VALUES (".$_POST['nom'].",".$_POST['prenom'].")";
    echo "sql=".$sql."<br/>";
    $connexion->exec($sql);
    	?>
    Dans le sql, dans VALUES, y a rien...
    c'est quoi le bug gros comme une maison ?

  2. #2
    Membre Expert
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2012
    Messages
    631
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Août 2012
    Messages : 631
    Par défaut
    salut,
    ton formulaire ne transmet pas les données en POST car à la place de l'attribut method du form tu as mis type
    Code html : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    <form action="action_patient.php" method="post">
    <table>
    <tr><td>Nom : </td><td><input type="text" name="nom" size="20"></td></tr>
    <tr><td>Prénom : </td><td><input type="text" name="prenom" size="20"></td></tr>
    <tr><td></td><td><input type="submit" name="envoyer" value="envoyer"></td></tr>
    </table>
    </form>

    ce qu'il faut toujours faire:
    -effectuer une vérification sur les données reçues
    -activer la gestion d'erreurs pdo
    -Échapper les données reçues

  3. #3
    Membre Expert
    Avatar de laurentSc
    Homme Profil pro
    Webmaster débutant perpétuel !
    Inscrit en
    Octobre 2006
    Messages
    10 493
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Webmaster débutant perpétuel !
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 493
    Billets dans le blog
    1
    Par défaut
    J'avais raison de parler de gros bug ; en fait, il y en avait 2 ("type" au lieu de "method" et données non échappées) mais il doit y en avoir un 3e car l'action, erreur 500... (pas trouvée)
    (et dis-moi si la gestion des erreurs de pdo est correcte) :

    Code html : 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
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    <?php
    header('Content-type: text/html; charset=UTF-8');
    session_start();
    ?>
    <!DOCTYPE html>
    <html>
      <head>
        <meta content="text/html; charset=utf-8" http-equiv="content-type">
        <title></title>
    	    <meta content="text/html; charset=utf-8" http-equiv="content-type">
        <title></title>
     <link rel="stylesheet" href="http://code.jquery.com/ui/1.10.3/themes/smoothness/jquery-ui.css">
     
      <script src="http://code.jquery.com/jquery-1.9.1.js"></script>
     
      <script src="http://code.jquery.com/ui/1.10.3/jquery-ui.js"></script>
     
      <link rel="stylesheet" href="/resources/demos/style.css">
     
      <script>
     
      $(function() {
     
        $( "#datepicker" ).datepicker({
     
          changeMonth: true,
     
          changeYear: true
     
        });
     
      });
     
      </script>	
      </head>
      <body>
     
    <?php include("menu.html"); ?>
    <form action="action_patient.php" method="post">
    <table>
    <tr><td>Nom : </td><td><input type="text" name="nom" size="20"></td></tr>
    <tr><td>Prénom : </td><td><input type="text" name="prenom" size="20"></td></tr>
    <tr><td>Date naissance : </td><td><input type="text" name="date_naissance" id="datepicker"></td></tr>
    <tr><td></td><td><input type="submit" value="envoyer"></td></tr>
    </table>
    </form>
     
      </body>
    </html>

    action_patient.php :
    Code php : 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
        <?php
     function setFrenchDate($date) {
    		$dateintermediaire=date_parse_from_format("d/m/Y",$date); //strptime marche pas
    		$day=$dateintermediaire['day'];
    		$month=$dateintermediaire['month'];
    		$year=$dateintermediaire['year'];
    		return($year."-".$month."-".$day);//conversion fr->ISO (format bdd)
     
    	} 	
     
    try {
    $PARAM_hote='---'; // le chemin vers le serveur
    $PARAM_nom_bd='---'; // le nom de votre base de données
    $PARAM_utilisateur='---'; // nom d'utilisateur pour se connecter
    $PARAM_mot_passe='---'; // mot de passe de l'utilisateur pour se connecter
    $connexion = new PDO('mysql:host='.$PARAM_hote.';dbname='.$PARAM_nom_bd, $PARAM_utilisateur, $PARAM_mot_passe);	
    $sql="INSERT INTO `patient` (nom,prenom,date_naissance) VALUES ("\"".$_POST['nom']."\",\"".$_POST['prenom']."\",\"".setFrenchDate($_POST['date_naissance'])."\")";
    //$sql="INSERT INTO `patient` (nom,prenom) VALUES (".$_POST['nom'].",".$_POST['prenom'].")";
    echo "sql=".$sql."<br/>";
    $connexion->exec($sql);
    }
     
    catch(PDOException $e) {
        $msg = 'ERREUR PDO dans ' . $e->getFile() . ' L.' . $e->getLine() . ' : ' . $e->getMessage();
        die($msg);
    }
     
    	?>
    (je n'ai pas resimplifié le code)

  4. #4
    Modératrice
    Avatar de Celira
    Femme Profil pro
    Développeuse PHP/Java
    Inscrit en
    Avril 2007
    Messages
    8 633
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Développeuse PHP/Java
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2007
    Messages : 8 633
    Par défaut
    Question bête : les deux fichiers sont bien dans le même dossier ?

    Au passage, il faudrait échapper les données dans ta requête en utilisant PDO::quote (ou en passant par une requête préparée)
    Modératrice PHP
    Aucun navigateur ne propose d'extension boule-de-cristal : postez votre code et vos messages d'erreurs. (Rappel : "ça ne marche pas" n'est pas un message d'erreur)
    Cherchez un peu avant poser votre question : Cours et Tutoriels PHP - FAQ PHP - PDO une soupe et au lit !.

    Affichez votre code en couleurs : [CODE=php][/CODE] (bouton # de l'éditeur) et [C=php][/C]

  5. #5
    Invité
    Invité(e)
    Par défaut
    Bonjour Laurent,
    là tu fais vraiment peur !
    • mauvaise utilisation de <table>,
    • pas de vérification des données transmises ni de gestion d'erreur,
    • requête non-sécurisée,
    • ...

    C'est une vraie PASSOIRE que tu nous proposes là !

    A LIRE ABSOLUMENT :

  6. #6
    Rédacteur

    Avatar de Bovino
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juin 2008
    Messages
    23 647
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Gironde (Aquitaine)

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

    Informations forums :
    Inscription : Juin 2008
    Messages : 23 647
    Billets dans le blog
    20
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    "INSERT INTO `patient` (nom,prenom,date_naissance) VALUES ("\""
    Pas de question technique par MP !
    Tout le monde peut participer à developpez.com, vous avez une idée, contactez-moi !
    Mes formations video2brain : La formation complète sur JavaScriptJavaScript et le DOM par la pratiquePHP 5 et MySQL : les fondamentaux
    Mon livre sur jQuery
    Module Firefox / Chrome d'intégration de JSFiddle et CodePen sur le forum

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

Discussions similaires

  1. Non affichage des données dans le formulaire
    Par enkie dans le forum IHM
    Réponses: 11
    Dernier message: 11/07/2008, 13h25
  2. Récupération des données d'un formulaire
    Par amtdev dans le forum Général JavaScript
    Réponses: 1
    Dernier message: 06/07/2007, 15h19
  3. [Tableaux] Récupération des données d'un formulaire
    Par projetM dans le forum Langage
    Réponses: 3
    Dernier message: 22/05/2006, 00h01
  4. Réponses: 3
    Dernier message: 23/04/2006, 12h14
  5. Récupération des données d'un formulaire
    Par placenargac dans le forum Balisage (X)HTML et validation W3C
    Réponses: 2
    Dernier message: 04/02/2006, 15h10

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