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 :

Confirmer l'affichage des valeurs sélectionnées par listes déroulantes


Sujet :

AJAX

  1. #41
    Invité
    Invité(e)
    Par défaut
    Bonjour Claudine,
    la récupération des id et des noms s'effectue dans cette partie du code :
    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
    	//---------------------
    	// categorie/selection : on récupère les id
    	$_SESSION['post_form']['id_categorie'] = $id_categorie = isset($_POST['id_categorie']) && trim($_POST['id_categorie']) != '' ? Verif_magicquotes(trim($_POST['id_categorie'])) : null;
     	$_SESSION['post_form']['id_selection'] = $id_selection = isset($_POST['id_selection']) && trim($_POST['id_selection']) != '' ? Verif_magicquotes(trim($_POST['id_selection'])) : null;
    	//---------------------
    	// on récupère les noms dans la BdD => SI ON A BESOIN DE LES AFFICHER ou les transmettre via email.......
    	if( is_numeric($id_categorie) && $id_categorie>0)
    	{
    		$cat_nom_sql = "SELECT nom_categorie FROM T_CATEGORIES WHERE id_categorie = ".mysql_real_escape_string($id_categorie).";";
    		$cat_nom_row = mysql_fetch_assoc($cat_nom_sql);
    		$_SESSION['post_form']['nom_categorie'] = $nom_categorie = $cat_nom_row['nom_categorie'];
    	} else {
    		$_SESSION['post_form']['nom_categorie'] = $nom_categorie = '';
    	}
    	if( is_numeric($id_selection) && $id_selection>0)
    	{
    	$selection_nom_sql = "SELECT nom_selection FROM T_SELECTIONS WHERE id_selection = ".mysql_real_escape_string($id_selection).";";
    		$selection_nom_row = mysql_fetch_assoc($selection_nom_sql);
    		$_SESSION['post_form']['nom_selection'] = $nom_selection = $selection_nom_row['nom_selection'];
    	} else {
    		$_SESSION['post_form']['nom_selection'] = $nom_selection = '';
    	}
    	//---------------------
    Or, il ne me semble pas qu'il y ait des erreurs.

    Afin de tester ce code, on va y ajouter des echo :
    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
    29
    30
    	//---------------------
    	// categorie/selection : on récupère les id
    	$_SESSION['post_form']['id_categorie'] = $id_categorie = isset($_POST['id_categorie']) && trim($_POST['id_categorie']) != '' ? Verif_magicquotes(trim($_POST['id_categorie'])) : null;
    echo 'id_categorie : '.$_SESSION['post_form']['id_categorie'].'<br />';
     	$_SESSION['post_form']['id_selection'] = $id_selection = isset($_POST['id_selection']) && trim($_POST['id_selection']) != '' ? Verif_magicquotes(trim($_POST['id_selection'])) : null;
    echo 'id_selection : '.$_SESSION['post_form']['id_selection'].'<br />';
    	//---------------------
    	// on récupère les noms dans la BdD en fonction des id
    	if( is_numeric($id_categorie) && $id_categorie>0)
    	{
    		$categorie_nom_sql = "SELECT nom_categorie FROM T_CATEGORIES WHERE id_categorie = ".mysql_real_escape_string($id_categorie).";";
    echo 'requete categorie : '.$categorie_nom_sql.'<br />';
    		$categorie_nom_row = mysql_fetch_assoc($categorie_nom_sql);
    		$_SESSION['post_form']['nom_categorie'] = $nom_categorie = $categorie_nom_row['nom_categorie'];
    	} else {
    		$_SESSION['post_form']['nom_categorie'] = $nom_categorie = '';
    	}
    echo 'nom categorie : '.$_SESSION['post_form']['nom_categorie'].'<br />';
    	if( is_numeric($id_selection) && $id_selection>0)
    	{
    	$selection_nom_sql = "SELECT nom_selection FROM T_SELECTIONS WHERE id_selection = ".mysql_real_escape_string($id_selection).";";
    echo 'requete selection : '.$selection_nom_sql.'<br />';
    		$selection_nom_row = mysql_fetch_assoc($selection_nom_sql);
    		$_SESSION['post_form']['nom_selection'] = $nom_selection = $selection_nom_row['nom_selection'];
    	} else {
    		$_SESSION['post_form']['nom_selection'] = $nom_selection = '';
    	}
    echo 'nom selection : '.$_SESSION['post_form']['nom_selection'].'<br />';
    var_dump($_SESSION['post_form']);
    	//---------------------
    => fais un copier-coller du code ci-dessus

    => Peux-tu montrer ce que tu obtiens ?

  2. #42
    Membre régulier
    Profil pro
    Inscrit en
    Février 2008
    Messages
    293
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Février 2008
    Messages : 293
    Points : 95
    Points
    95
    Par défaut
    Bonjour Jreaux62,
    voici la réponse du formulaire de confirmation:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    Veuillez contrôler vos coordonnées et cliquer sur confirmer si celles-ci sont correctes, dans le cas contraire cliquer sur modifier 
    Votre mot de passe : fgh1489
     
    Votre catégorie : 
     
    Votre selection : 
     
     
    Votre nom : Cgkjp
     
    Votre prenom : Cvuo
     
    Votre téléphone : 067332088
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    Array ( 
       [post_form] => Array ( 
          [message] => Array ( ) 
          [motdepasse] => fgh1489 
          [nom] => Cgkjp 
          [prenom] => Cvuo 
          [numtel] => 067332088 
          [id_categorie] => 3 
          [id_selection] => 6 
          [nom_categorie] => 
          [nom_selection] => 
       ) 
    )
    Pas d'affichage de l'echo.
    claudine

  3. #43
    Invité
    Invité(e)
    Par défaut
    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    		header('Location: confirm1.php');// envoi à la page confirmation "Confirm1.php"
    Commente cette ligne :
    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    	//	header('Location: confirm1.php');// envoi à la page confirmation "Confirm1.php"

  4. #44
    Membre régulier
    Profil pro
    Inscrit en
    Février 2008
    Messages
    293
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Février 2008
    Messages : 293
    Points : 95
    Points
    95
    Par défaut
    Bonjour Jreaux62

    Lorsque mon formulaire d'inscription 'FormInscriptionAjax.php' n'affiche pas d'erreur des coordonnées obligatoires je clique sur envoyer qui me dirige vers le formulaire 'confirm1' pour confirmer et envoyer en bdd ou retour vers le formulaire pour modification.
    Sincères salutations
    Claudine

  5. #45
    Invité
    Invité(e)
    Par défaut
    Ça, j'ai bien compris !

    Je veux que tu commentes la ligne, pour pouvoir afficher les echo !


    N.B. il faudrait aussi que tu y mettes un peu du tien, et que tu prennes des initiatives !
    Je ne peux pas prendre le contrôle de ton ordinateur à distance...

  6. #46
    Membre régulier
    Profil pro
    Inscrit en
    Février 2008
    Messages
    293
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Février 2008
    Messages : 293
    Points : 95
    Points
    95
    Par défaut
    Bonjour jreaux62,
    Voilà, j'ai indiqué dans confirm2.php :
    J'y ai ajoué echo "$id_categorie"; il me retourne variable indéfinie

    Notice: Undefined variable: nom_categorie in C:\Program Files\EasyPHP-5.3.3.1\www\infopub\confirm2.php on line 71

    Notice: Undefined variable: id_categorie in C:\Program Files\EasyPHP-5.3.3.1\www\infopub\confirm2.php on line 72 alors que confirm2.php affiche la variable id_catégorie!

    Même chose si je remplace comfirm2 par echo.php

    Merci pour votre compréhension.
    Claudine

  7. #47
    Invité
    Invité(e)
    Par défaut
    Bonjour Claudine,

    J'ai tout repris depuis le début... réécris tous les fichiers et tout corrigé.

    Je ne comprends même pas que tu aies réussi à faire cohabiter mysql_ (obsolète) et PDO !
    => J'ai tout passé en PDO


    connect-bd.php
    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    <?php
    // --------------------------------------------------------------
    // Paramètres de connection a la Base de Données sur le serveur
    // --------------------------------------------------------------
    	$pdo_options[PDO::ATTR_ERRMODE] = PDO::ERRMODE_EXCEPTION;
    	$pdo_options[PDO::MYSQL_ATTR_INIT_COMMAND]  = 'SET NAMES utf8';
    	$pdo_options[PDO::ATTR_EMULATE_PREPARES] = false;
    	$bdd = new PDO('mysql:host=localhost;dbname=clients', 'root', '', $pdo_options);
    // --------------------------------------------------------------
    FormInscriptionAjax.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
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    115
    116
    117
    118
    119
    120
    121
    122
    123
    124
    125
    126
    127
    128
    129
    130
    131
    132
    133
    134
    135
    136
    137
    138
    139
    140
    141
    142
    143
    144
    145
    146
    147
    148
    149
    150
    151
    152
    153
    154
    155
    156
    157
    158
    159
    160
    161
    162
    163
    164
    165
    166
    167
    168
    169
    170
    171
    172
    173
    174
    175
    176
    177
    178
    179
    180
    181
    182
    183
    184
    185
    186
    187
    188
    189
    190
    191
    192
    193
    194
    195
    196
    197
    198
    199
    200
    201
    202
    203
    204
    205
    206
    207
    208
    209
    210
    211
    212
    213
    214
    215
    216
    217
    218
    219
    220
    221
    222
    223
    224
    225
    226
    227
    228
    229
    230
    231
    232
    233
    234
    235
    236
    237
    238
    239
    240
    241
    242
    243
    244
    245
    246
    247
    248
    249
    250
    251
    252
    253
    254
    255
    256
    257
    258
    259
    260
    261
    262
    263
    264
    265
    266
    267
    268
    269
    270
    271
    272
    273
    274
    275
    276
    277
    278
    279
    280
    281
    282
    283
    284
    285
    286
    287
    288
    289
    290
    291
    <?php
    if (!session_id()) session_start(); //déclare l'ouverture d'une session si aucune n'a été déclarée auparavant.
    header('Content-Type: text/html; charset=UTF-8" '); // affichage correct des accents
    //-----------------------------
    // connection à la DB
            include('./connect-bd.php');
    //-----------------------------
    // TRAITEMENT du formulaire
    if (isset($_POST['envoyer']))
    {
            //---------------------
            // fonction qui applique stripslashes si get_magic_quotes_gpc() est activé
            function Verif_magicquotes ($chaine)
            {
                    // N.B. : A PRIORI, CETTE FONCTION N'A PLUS D'UTILITE !!
                    if (get_magic_quotes_gpc()) $chaine = stripslashes($chaine);
                    return $chaine;
            }
            //---------------------
            $message = array(); // Pour enregistrer les messages d'information
            $_SESSION['post_form']['message'] =& $message;// avec & on assigne $message à $_SESSION['post_form']['message'] c.a.d. tout changement dans $message sera répercuté dans $_SESSION['post_form']['message']
            // Récupération des données
            $_SESSION['post_form']['motdepasse'] = $motdepasse = isset($_POST['motdepasse']) && trim($_POST['motdepasse']) != '' ? Verif_magicquotes(trim($_POST['motdepasse'])) : null;
            $_SESSION['post_form']['nom'] = $nom = isset($_POST['nom']) && trim($_POST['nom']) != '' ? Verif_magicquotes(ucfirst(trim($_POST['nom']))) : null;//ucfirst pour convertir le première lettre en majuscule
            $_SESSION['post_form']['prenom'] = $prenom = isset($_POST['prenom']) && trim($_POST['prenom']) != '' ? Verif_magicquotes(ucfirst(trim($_POST['prenom']))) : null;//ucfirst pour convertir le première lettre en majuscule
            $_SESSION['post_form']['numtel'] = $numtel = isset($_POST['numtel']) && trim($_POST['numtel']) != '' ? Verif_magicquotes(trim($_POST['numtel'])) : null;
            //---------------------
            // categorie/selection : on récupère les id
            $_SESSION['post_form']['id_categorie'] = $id_categorie = isset($_POST['id_categorie']) && trim($_POST['id_categorie']) != '' ? Verif_magicquotes(trim($_POST['id_categorie'])) : null;
            $_SESSION['post_form']['id_selection'] = $id_selection = isset($_POST['id_selection']) && trim($_POST['id_selection']) != '' ? Verif_magicquotes(trim($_POST['id_selection'])) : null;
            //---------------------
            // on récupère les noms dans la BdD => SI ON A BESOIN DE LES AFFICHER ou les transmettre via email.......
            if( is_numeric($id_categorie) && $id_categorie>0)
            {
                    $categorie_nom_sql = "SELECT nom_categorie FROM T_CATEGORIES WHERE id_categorie = ?;";
                    $categorie_nom_res = $bdd->prepare($categorie_nom_sql);                           
                    $categorie_nom_res->execute(array($id_categorie));
                    $categorie_nom_row = $categorie_nom_res->fetch();
                    $_SESSION['post_form']['nom_categorie'] = $categorie_nom_row['nom_categorie'];
            } else {
                    $_SESSION['post_form']['nom_categorie'] = '';
            }
            if( is_numeric($id_selection) && $id_selection>0)
            {
                    $selection_nom_sql = "SELECT nom_selection FROM T_SELECTIONS WHERE id_selection = ?;";
                    $selection_nom_res = $bdd->prepare($selection_nom_sql);                           
                    $selection_nom_res->execute(array($id_selection));
                    $selection_nom_row = $selection_nom_res->fetch();
                    $_SESSION['post_form']['nom_selection'] = $nom_selection = $selection_nom_row['nom_selection'];
            } else {
                    $_SESSION['post_form']['nom_selection'] = $nom_selection = '';
            }
            //---------------------
            // GESTION d'ERREURS - champs obligatoires / validité des champs
            if (!isset($motdepasse))
            {
                     $message[] = 'Veuillez choisir votre mot de passe';
            }
            //---------
            if (isset($nom))
            {
                    if (! preg_match('#^[a-zéèàçïêë \']{3,40}$#i',$nom)) 
                    {
                            $message[] = 'Le nom "'.$nom.'" n\'est pas valide. Minimum 3 lettres, maximum 12. Chiffres non autorisés. Recommencez !'; 
                    }
            }
            else
            {
                     $message[] = 'Veuillez indiquer votre nom';
            }
            //---------
            if (isset($prenom))
            {
                    if (! preg_match('#^[a-zéèàçïêë \']{3,40}$#i',$prenom))
                    {
                            $message[] = 'Le prénom "'.$prenom.'" n\'est pas valide. Minimum 3 lettres, maximum 12. Chiffres non autorisés. Recommencez !';
                    }
            }
            else
            {
                    $message[] = 'Veuillez indiquer votre prénom';
            }
            //---------#^[+]?[0-9. ]{6,30}$#
            if (isset($numtel))
            {
                    if (!preg_match("#^[+]?[0-9. ]{6,30}$#", $numtel))
                    {
                            $message[] = 'Le numéro de téléphone "'.$numtel.'" n\'est pas valide. Recommencez !';
                    }
            }
            else
            {
                    $message[] = 'Veuillez indiquer un numéro de téléphone';
            }
            //---------------------
            if (isset($motdepasse))
            {
                    if (!preg_match("#^[0-9a-zA-Z]+$#", $motdepasse))
                    {
                            $message[] = 'Le mot de passe ne doit contenir que des caractères alphanumériques (6 à 12 caractères).';
                    } elseif (!preg_match("#^[0-9a-zA-Z]{6,12}$#", $motdepasse))
                    {
                            $message[] = 'Le mot de passe doit contenir entre 6 et 12 caractères alphanumériques.';
                    } else 
                    {
                            // requête pour vérifier si le mot de passe est déjà pris :
                            try
                            {
                                    $req = $bdd->prepare('SELECT count(*) as nb FROM coordonnees WHERE motdepasse = ?');
                                    $req->execute(array($motdepasse));
                                    $result = $req->fetch(PDO::FETCH_OBJ);
                                    if($result->nb != 0)
                                    {
                                            $message[] = 'Ce mot de passe est déjà utilisé';
                                    }
                            }
                            catch(Exception $e)
                            {
                                    die('Erreur : '.$e->getMessage());
                            }
                    }
            }
            //---------------------
            // Pas d'Erreurs -> ENVOI de confirmation
            if (empty($message))
            {
                    header('location: confirm1.php');// envoi à la page confirmation "Confirm1.php"
                    exit;
            }
            //---------------------
    }
    //-----------------------------
    ?>
    <!DOCTYPE HTML>
    <html dir="ltr" lang="fr">
    <head>
            <meta charset="utf-8" />
            <title>Formulaire d'Inscription</title>
     
    <script src="scripts/jquery.1.5.1.min.js"></script> 
    <script type="text/javascript">
            /* Initialisation XMLHttpRequest (obligatoire) */
            function getXhr(){
                    var xhr = null; 
                    if(window.XMLHttpRequest) // Firefox et autres
                       xhr = new XMLHttpRequest(); 
                    else if(window.ActiveXObject){ // Internet Explorer 
                            try {
                                    xhr = new ActiveXObject("Msxml2.XMLHTTP");
                            } catch (e) {
                                    xhr = new ActiveXObject("Microsoft.XMLHTTP");
                            }
                    } else { // XMLHttpRequest non supporté par le navigateur 
                            alert ("Votre navigateur ne supporte pas les objets XMLHTTPRequest..."); 
                            xhr = false; 
                    } 
                    return xhr;
            };
     
            /* Changer la liste "Selection" après choix dans la liste "Categorie" */
            function changeSelectionParCategorie( id_categorie, iddiv_ajax ){
                    var id_categorie; // valeur de l option ("id_ategorie") choisie
                    var iddiv_ajax; // id du div dans lequel on remplira la liste des "selections"
                    var nom_categorie;
                    var xhr = getXhr();
                    xhr.onreadystatechange = function(){
                            if(xhr.readyState == 4 && xhr.status == 200)
                            {
                                    texthtml = xhr.responseText;
                                    // innerHTML va ajouter les options a la liste des "selections"
                                    document.getElementById(iddiv_ajax).innerHTML = texthtml;
                            }
                    }
                    // on defini la methode (post) + le fichier de traitement + asynchrone (true)
                    xhr.open("POST","ajaxSelectionsFromCategorie.php",true);
                    // ne pas oublier ça pour le post
                    xhr.setRequestHeader('Content-Type','application/x-www-form-urlencoded');
                    // on poste les parametres a transmettre au fichier qui fera le traitement
                    xhr.send("id_categorie="+id_categorie);
            };
    </script>
     
    <style>
    #formulaireBox { width:48em; margin:auto; border:1px solid black; padding:1em; }
    #formulaireBox label { display:inline-block; min-width: 150px; }
    #msgerreurBox { font-size:0.8em; font-weight:bold; color:red; }
    </style>
    </head>
     
    <body>
     
    <div id="formulaireBox">
            <h4>Formulaire</h4>
            <form action="#" method="post" id = "form_identification">      
     
                    <legend>1: Choisissez d'abord une catégorie. 2: Ensuite une sélection.</legend> 
     
                    <p>
                            <label for="idid_categorie">1. Categorie : </label>
                            <select id="id_categorie" name="id_categorie" onChange="changeSelectionParCategorie(this.options[this.selectedIndex].value,'iddiv2');">
                                    <!-- on appelle la fct sur le onchange (valeur-choisie, id-du-div-à-remplir) -->
                                    <option value="-1">Choisir une catégorie</option>
    <?php
                                    // requete : liste de toutes les categories
                                    $cat_sql = "SELECT id_categorie, nom_categorie FROM T_CATEGORIES ORDER BY nom_categorie ASC;";
                                    $cat_res = $bdd->prepare($cat_sql);                               
                                    $cat_res->execute(array());
                                    while($cat_row = $cat_res->fetch())
                                    {
                                            $selected = (isset($_SESSION['post_form']['id_categorie']) && $_SESSION['post_form']['id_categorie']==$cat_row['id_categorie'])? ' selected="selected"' : '';
    ?>
                                    <option value="<?php echo $cat_row['id_categorie']; ?>"<?php echo $selected; ?>><?php echo $cat_row['nom_categorie']; ?></option>
    <?php                   } ?>
    			</select>
    		</p>
     
    		<p>
    			<label for="idid_selection">2. Sélection : </label>
    			<span id="iddiv2"><!-- c'est ici que par innerHTML AJAX va ecrire la liste2 -->
    			<select id="idid_selection" name="id_selection">
    <?php           // déjà une catégorie choisie
                            if( isset($_SESSION['post_form']['id_categorie']) && $_SESSION['post_form']['id_categorie']>0){
    ?>
    				<option value="-1">Choisir une sélection</option>
    <?php			// requete : la liste des "selections" de la categorie choisie
    				$sel_sql = "SELECT id_selection, nom_selection FROM T_SELECTIONS WHERE id_categorie = ? ORDER BY nom_selection ASC;";	
    				$sel_res = $bdd->prepare($sel_sql);				  
    				$sel_res->execute(array($_SESSION['post_form']['id_categorie']));
    				while($sel_row = $sel_res->fetch())
    				{
    					$selected = (isset($_SESSION['post_form']['id_selection']) && $_SESSION['post_form']['id_selection']==$sel_row['id_selection'])? ' selected="selected"' : '';
    ?>
     
    				<option value="<?php echo $sel_row['id_selection']; ?>"<?php echo $selected; ?>><?php echo $sel_row['nom_selection']; ?></option>
    <?php
                                    }
                            // SI pas de categorie choisie (-1) ou erreur : on met le select "par defaut" :
                            } else { 
    ?>
    				<option value="-1">Choisissez d'abord une catégorie</option>
    <?php
                            } 
    ?>
    			</select>
    			</span>
    		</p>
     
    		<p>
    			<label for="idmotdepasse"> Mot de passe :</label>
    			<input type="text" id="idmotdepasse" name="motdepasse" value="<?php echo (isset($_SESSION['post_form']['motdepasse'])) ? $_SESSION['post_form']['motdepasse'] : '' ?>" />
    		</p>
     
    		<p>
    			<label for="idnom"> Nom :</label>
    			<input type="text" id="idnom" name="nom" value="<?php echo (isset($_SESSION['post_form']['nom'])) ? $_SESSION['post_form']['nom'] : '' ?>" />
    		</p>
     
    		<p>
    			<label for="idprenom"> Prénom :</label>
    			<input type="text" id="idprenom" name="prenom" value="<?php echo (isset($_SESSION['post_form']['prenom'])) ? $_SESSION['post_form']['prenom'] : '' ?>" />
    		</p>
     
    		<p>
    			<label for="idnumtel"> N° de téléphone :</label>
    			<input type="text" id="idnumtel" name="numtel" value="<?php echo (isset($_SESSION['post_form']['numtel'])) ? $_SESSION['post_form']['numtel'] : '' ?>" />
    		</p>
     
    		<p style="margin-top:1.5em">
    			<input name="envoyer" value="Envoyer" type="submit"/>
    		</p>	  
     
    	</form>
    <?php
    if(!empty($_SESSION['post_form']['message']))
    {
    ?>
    	<ul id="msgerreurBox">
    <?php
            foreach($_SESSION['post_form']['message'] as $value)
            {
                    echo '<li>'.$value.'</li>';
            }
    ?>
    	</ul>
    <?php
    }
    ?>
    </div>
     
    </body>
    </html>
    ajaxSelectionsFromCategorie.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
    29
    30
    31
    32
    33
    34
    35
    <?php session_start();
    header('Content-Type: text/html; charset=UTF-8" '); // affichage correct des accents
    //-----------------------------
    // Ajax : Charger la liste "Selection" après choix dans la liste "Categorie"
    if(isset($_POST['id_categorie']) && is_numeric($_POST['id_categorie']) && $_POST['id_categorie']>0)
    {
    	//---------------------
    	// connection  la DB
    	include('./connect-bd.php'); 
    	//---------------------
    ?>
    			<select id="idid_selection" name="id_selection">
    				<option value="-1">Choisir une sélection</option>
    <?php			// requete : la liste des "selections" de la categorie choisie
    				$sel_sql = "SELECT id_selection, nom_selection FROM T_SELECTIONS WHERE id_categorie = ? ORDER BY nom_selection ASC;";	
    				$sel_res = $bdd->prepare($sel_sql);				  
    				$sel_res->execute(array($_POST['id_categorie']));
    				while($sel_row = $sel_res->fetch())
    				{
    					$selected = (isset($_SESSION['post_form']['id_selection']) && $_SESSION['post_form']['id_selection']==$sel_row['id_selection'])? ' selected="selected"' : '';
    ?>
    				<option value="<?php echo $sel_row['id_selection']; ?>"<?php echo $selected; ?>><?php echo $sel_row['nom_selection']; ?></option>
     
    <?php
    				}
    ?>
    			</select>
    <?php
    } else { // SI pas de categorie choisie (-1) ou erreur : on remet le select "par defaut" :
    ?>
    			<select id="idid_selection" name="id_selection">
    				<option value="-1">Choisissez d'abord une catégorie</option>
    			</select>
    <?php
    }

    confirm1.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
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    <?php session_start();
    //-----------------------------
    // connection à la DB
    	include('./connect-bd.php');
    //-----------------------------
    // Modification
    if (isset($_POST["modif"]))
    {
    	header('Location: FormInscriptionAjax.php');// mettre le nom du fichier de ton formulaire "
    	exit;
    }
    //-----------------------------
    // Confirmation
    if (isset($_POST['conf'], $_SESSION['post_form']))
    {
    	// enregistrement des données de session en bdd
    	try {
    		// Insertion du message à l'aide d'une requête préparée
    		$sql = 'INSERT INTO coordonnees (motdepasse, nom_categorie, nom_selection, nom, prenom, numtel,ville,SiteWeb,MaPage,infos,horaire,Ouverture,adresse,mail) VALUES(?, ?, ?,?, ?, ?,?, ?, ?,?,?,?,?,?)';
    		$req = $bdd->prepare($sql);				  
    		$req->execute(array($_SESSION['post_form']['motdepasse'], $_SESSION['post_form']['nom_categorie'], $_SESSION['post_form']['nom_selection'], $_SESSION['post_form']['nom'], $_SESSION['post_form']['prenom'],$_SESSION['post_form']['nom_province'], $_SESSION['post_form']['numtel'],  $_SESSION['post_form']['ville'],$_SESSION['post_form']['SiteWeb'], $_SESSION['post_form']['MaPage'],$_SESSION['post_form']['infos'],$_SESSION['post_form']['horaire'],$_SESSION['post_form']['Ouverture'],$_SESSION['post_form']['adresse'],$_SESSION['post_form']['mail']));
    		unset($_SESSION['post_form']);
     
    		//redirection vers la page d'index
    		header('Location: Accueil.html');
    		exit;
    	}
    	catch(Exception $e)
    	{
    		die('Erreur : '.$e->getMessage());
    	}
    }
    //-----------------------------
    //... (Ne pas oublier le "exit;" après un header Location) 
    ?>
    <!DOCTYPE html>
    <html dir="ltr" lang="fr">
    <head>
    	<meta charset="utf-8" />
    	<title>Confirmation</title>
    <style>
    #confirmationBox  { width:48em; margin:auto; border:1px solid black; padding:1em; }
    #confirmationBox label { display:inline-block; min-width: 150px; }
    </style>
    </head>
     
    <body>
     
    <div id="confirmationBox">
    	<h4>Veuillez contrôler vos coordonnées</h4>
    	<strong>Cliquez sur <em>confirmer</em> si celles-ci sont correctes, sinon cliquez sur <em>modifier</em></strong>
    	<p>
    		<label>Votre catégorie : </label>
    		<?php echo isset($_SESSION['post_form']['nom_categorie'])? $_SESSION['post_form']['nom_categorie'] : '' ?>
    	</p>
    	<p>
    		<label>Votre sélection : </label>
    		<?php echo isset($_SESSION['post_form']['nom_selection'])? $_SESSION['post_form']['nom_selection'] : '' ?>
    	</p>
    	<p>
    		<label>Votre mot de passe : </label>
    		<?php echo isset($_SESSION['post_form']['motdepasse'])? $_SESSION['post_form']['motdepasse'] : '' ?>
    	</p>
    	<p>
    		<label>Votre nom : </label>
    		<?php echo isset($_SESSION['post_form']['nom'])? $_SESSION['post_form']['nom'] : '' ?>
    	</p>
    	<p>
    		<label>Votre prenom : </label>
    		<?php echo isset($_SESSION['post_form']['prenom'])? $_SESSION['post_form']['prenom'] : '' ?>
    	</p>
    	<p>
    		<label>Votre téléphone : </label>
    	<?php echo isset($_SESSION['post_form']['numtel'])? $_SESSION['post_form']['numtel'] : '' ?>
    	</p>
    	<p>
    	<form action = '#' method = "post" >
    		<input type = "submit" value = "modifier" name= "modif" />
    		<input type = "submit" value = "confirmer" name= "conf" />
    	</form>
    	</p>
    	<p>
    	<a href="Accueil.html">Accueil</a>
    	</p>
    </div>
     
    <?php
    //print_r($_SESSION)
    ?>
     
    </body>
    </html>
    Dernière modification par Invité ; 24/10/2015 à 11h19.

  8. #48
    Membre régulier
    Profil pro
    Inscrit en
    Février 2008
    Messages
    293
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Février 2008
    Messages : 293
    Points : 95
    Points
    95
    Par défaut
    Bonjour Jreaux62,
    Je tiens à vous exprimer ma gratitude pour ce travail fastidieux.
    Il subsiste pour l'instant un petit problème que je n'arrive pas à résoudre: ma liste selection n'est pas chargée.
    Cependant un grand espoir de réussite totale existe puisque la valeur 'nom_categorie' s'affiche enfin dans le formulaire de confirmation.
    Voulez-vous vérifier la requête de selection?(id_categorie=?) Le id_categorie doit correspondre au POST_form--->id_selection
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    $sel_sql = "SELECT id_selection, nom_selection FROM T_SELECTIONS WHERE id_categorie = ? ORDER BY nom_selection ASC;";
    Sincère remerciement

    Claudine

  9. #49
    Invité
    Invité(e)
    Par défaut
    Bonjour Claudine,

    si tu as COPIE-COLLE TELS QUELS mes fichiers (Y COMPRIS connect-bd.php), tu ne devrais plus avoir le moindre problème.
    (-> voir mon message précédent)

    • J'ai nettoyé et enlevé de tes fichiers les bouts de code inutiles (les connexions redondantes,...)
    • J'ai créé une base et des tables SQL pour mes tests
    • J'ai vérifié et testé toute la procédure (sauf la vérification de mot de passe en BdD et l'enregistrement final)
    • ...

    Bref : LA TOTALE.

    [EDIT] J'ai ajouté une petite "rustine", pour vérifier que le mot de passe ne fait que 6 à 12 caractères alphanumériques.
    (-> voir mon message précédent)


    Information :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    				$sel_sql = "SELECT id_selection, nom_selection FROM T_SELECTIONS WHERE id_categorie = ? ORDER BY nom_selection ASC;";	
    				$sel_res = $bdd->prepare($sel_sql);				  
    				$sel_res->execute(array($_POST['id_categorie']));
    Il s'agit ici d'une requête préparée, avec PDO.
    Le ? dans la requête est repris dans array($_POST['id_categorie']).
    Dernière modification par Invité ; 24/10/2015 à 11h11.

  10. #50
    Membre régulier
    Profil pro
    Inscrit en
    Février 2008
    Messages
    293
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Février 2008
    Messages : 293
    Points : 95
    Points
    95
    Par défaut
    Bonjour Jreaux62,

    Encore merci pour ce travail énorme avec Ajax , ce qui m'a permis d'approfondir. Heureux de constater que les listes gardent les valeurs sélectionnées.
    Ainsi donc j'ai refait un autre logiciel avec 2 listes déroulantes liées (provinces et villes).
    Il fonctionne mais il y a un problème puisque les 2 listes affichent leur valeurs respectives puis je confirme et par essai je clique sur modifier et au retour sur mon formulaire d'inscription je constate que seule la première liste déroulante garde la valeur sélectionnée. la 2ème(liste des villes affiche "sélectionner une ville" et a donc perdu la valeur selectionnée. Où peut se situer le problème?

    Voulez-vous m'aider?

    Claudine

  11. #51
    Membre régulier
    Profil pro
    Inscrit en
    Février 2008
    Messages
    293
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Février 2008
    Messages : 293
    Points : 95
    Points
    95
    Par défaut
    Bonjour Jreaux62,
    Mille excuses de vous avoir sollicité, mais après relecture(une de plus) de l'ensemble je me suis apperçue que j'avais omis la condition WHERE dans une requête.
    Encore tous mes remerciements pour votre aide qui m'a permis de progresser à grand pas dans mes projets qui sont ma passion.
    Claudine

  12. #52
    Membre régulier
    Profil pro
    Inscrit en
    Février 2008
    Messages
    293
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Février 2008
    Messages : 293
    Points : 95
    Points
    95
    Par défaut
    bonjour Jreaux62,

    Je n'arrive pas à solutionner le petit problème suivant et à cet effet je jopins ci-dessous une partie du code de mon formulaire:
    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
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
     
    <p>
    				<label for="SiteWeb"> SiteWeb :</label>
    				<input type="text" id="SiteWeb" name="SiteWeb" value="<?php echo (isset($_SESSION['post_form']['SiteWeb'])) ? $_SESSION['post_form']['SiteWeb'] : '' ?>" />
    			</p>
     
    		  <p>
    			 Voulez-vous une page info personnelle ?
                               </p>            
    <script >
    	 function Lien(obj)	 
    	 { 
    	 i=obj.selectedIndex;
    	 if (i == 0)
    	     return false;
    		 url=obj.options[i].value;
    		 document.getElementById('I1').src= url;
    	  }
    </script>
     
    <form name="MaPage">
    <select size="1" name="MaPage" onChange="Lien(this);">
      <option selected>choisissez</option>
      <option value="NosINFOS.html">oui</option>
      <option value="PasD'INFOS.html">non</option>
    </select>
    <p> Si oui,tapez votre
    			<label for="infos"> infos :</label>
    				   <textarea name="infos"  tabindex="4" cols="30" rows="8" id="infos"><?php echo (isset($_SESSION['post_form']['infos'])) ? $_SESSION['post_form']['infos'] : '' ?></textarea>
    </p>
     
      </option> 
     
     
     
          <p>
    			 Voulez-vous indiquer les heures d'ouverture ?
         </p> 
    <script >
    	 function Lien(obj)	 
    	 { 
    	 i=obj.selectedIndex;
    	 if (i == 0)
    	     return false;
    		 url=obj.options[i].value;
    		 document.getElementById('I2').src= url;
    	  }
    </script>
        <form name="Ouverture">
    	<select size="1" name="Ouverture" onChange="Lien(this);">
                  <option selected>choisissez</option>
            <option value="NotreHoraire.html">oui</option>
            <option value="PasD'Horaire.html">non</option>
          </select>
     
        <p> Si oui, tapez votre 
    			<label for="horaire"> horaire :</label>
     
                <textarea name="horaire"  tabindex="5" cols="30" rows="9" id="horaire"><?php echo (isset($_SESSION['post_form']['horaire'])) ? $_SESSION['post_form']['horaire'] : '' ?></textarea>
       </p> 
       </option>
    je voudrais afficher "NotreHoraire.html" pour la selection"Ouverture" si le choix est oui. ou l'inverse si 'non' et cet affichage est vide Pourquoi? alors que cela fonctionne correctement pour le 1erchoix : MaPage qui affiche
    ="NosINFOS.html" si oui.
    Voudriez-vous m'aider à résoudre ce problème?
    Remerciements
    Claudine

  13. #53
    Membre habitué
    Homme Profil pro
    rien
    Inscrit en
    Décembre 2015
    Messages
    282
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Aveyron (Midi Pyrénées)

    Informations professionnelles :
    Activité : rien

    Informations forums :
    Inscription : Décembre 2015
    Messages : 282
    Points : 144
    Points
    144
    Par défaut
    document.getElementById('I2').src= url;
    L'élément I2 il est où dans ton code HTML ? (pareil pour I1)

    Si tu veux afficher une url dans un objet référencé par I1 il faut que cet objet existe, par exemple un DIV :
    <div id="I1">Adresse</div>
    <div id="I2">Adresse</div>


    <option value="NotreHoraire.html">oui</option>
    <option value="PasD'Horaire.html">non</option>
    Ce ne sont pas des noms valides ça, les urls doivent toujours être en minuscules et sans apostrophes, que des caractères contigus.

    Une remarque hors sujet, ça fait bizarre de voir ton pseudo "Claudine" alors que tu écris au masculin
    Heureux de constater que les listes gardent les valeurs sélectionnées.

  14. #54
    Membre régulier
    Profil pro
    Inscrit en
    Février 2008
    Messages
    293
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Février 2008
    Messages : 293
    Points : 95
    Points
    95
    Par défaut
    Bonjour progdebutant ,

    Merci pour vos conseils: l'erreur est corrigée

    Claudine

Discussions similaires

  1. [Web Service] Problème d'affichage des valeurs renvoyées par un webservice
    Par informatique34 dans le forum Bibliothèques et frameworks
    Réponses: 6
    Dernier message: 11/07/2011, 13h34
  2. Recherche et affichage des valeurs d'une liste
    Par sat478 dans le forum Excel
    Réponses: 4
    Dernier message: 18/01/2009, 17h52
  3. Réponses: 5
    Dernier message: 01/08/2006, 14h39
  4. Eviter l'affichage des éléments d'une liste déroulante
    Par auriolbeach dans le forum Access
    Réponses: 1
    Dernier message: 28/02/2006, 07h50
  5. Affichage des mois dans une liste déroulante
    Par Le Rebel dans le forum Langage
    Réponses: 15
    Dernier message: 20/02/2006, 13h37

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