Précédent   Forum des professionnels en informatique > PHP > Langage > Formulaires
Formulaires Forum d'entraide sur les formulaires avec PHP. Avant de poster -> FAQ formulaires, Cours de formulaires et Sources de formulaires
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 24/05/2007, 09h47   #1
Invité régulier
 
Inscription : avril 2007
Messages : 31
Détails du profil
Informations forums :
Inscription : avril 2007
Messages : 31
Points : 5
Points : 5
Par défaut Soucis d'index indéfini

Bonjour,

je suis en train de créer un programme qui gére des utilisateurs (à l'aide d'une base de données) :
j'ai une page pour ajouter un nouvel utilisateur, une pour modifier, une pour se logger et une pour supprimer un compte...

C'est sur cette dernière page que j'ai un soucis :
Le code fonctionne trés bien mais j'ai juste un problème avec un index indéfini...

Voici mon code :
Code :
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
 
<form name="2" method="POST" action="Delete.php">
 
<div id="contenu">
<h2><center>Saisir vos caractéristiques</center></h2>
 
Nom : <center>
        <select name="nom" onchange="form.submit();">
                <option value="choix">Sélectionnez</option>
        <?php
                mysql_connect ("localhost", "root", "") ; // Connexion à MySQL
                mysql_select_db ("base") ; // Sélection de la base coursphp
                $rq = "SELECT nom FROM utilisateurs" ;
                $res = mysql_query($rq) or die (" erreur sur $rq : ".mysql_error()) ;
                while ($membre = mysql_fetch_assoc ($res))
                {
                        echo '<option value="'.$membre['nom'].'" ' ;
                        if (isset ($_POST['nom']) && $_POST['nom'] == $membre['nom'])
                        {
                                echo " SELECTED " ;
                        }
                        echo '>'.$membre['nom'].' </option>' ;
                }
        ?>
        </select></center><br>
        <?php
        if (isset ($_POST['nom']))
        {
                $nom = $_POST['nom'] ;
                $rq2 = "SELECT * FROM utilisateurs where nom='$nom'" ;
                $res2 = mysql_query ($rq2) or die (" erreur sur $rq2 : ".mysql_error()) ;
                $donnee = mysql_fetch_assoc ($res2) ;
 
                ?>
                Prénom : <center><input type="text" name="prenom" value="<?php echo $donnee['prénom'] ?>" ></center><br>
 
                Login : <center><input type="text" name="login"  value="<?php echo $donnee['login'] ?>" ></center><br>
 
                Password : <center><input type="text" name="pass"  value="<?php echo $donnee['pass'] ?>" ></center><br>
 
                Société : <center><input type="text" name="société"  value="<?php echo $donnee['société'] ?>" ></center><br>
 
                Adresse mail : <center><input type="text" name="adresse"  value="<?php echo $donnee['adresse'] ?>" ></center><br>
                <?php
        }
        mysql_close(); // Déconnexion de MySQL
        ?>
</div>
 
<div id="pied_page">
<br><br><input type="submit" value="Supprimer"><br><br>
</form>
<form action="Login.php">
<input type="submit" value="Retour">
</form>
</div>
 
 
<?php
mysql_connect("localhost", "root", ""); // Connexion à MySQL
mysql_select_db("base"); // Sélection de la base coursphp
 
if(!empty($_POST['nom']))
{
 
$nom = htmlentities($_POST ['nom'], ENT_QUOTES) ;
$prenom = htmlentities($_POST ['prenom'], ENT_QUOTES) ;
mysql_query("DELETE FROM utilisateurs WHERE nom = '$nom' AND prénom = '$prenom'") ;
 
$reponse = mysql_query('SELECT * FROM utilisateurs') ;
 
// Affichage de la table
while ($donnees = mysql_fetch_array($reponse) or die(mysql_error()) )
{
?>
 
<p>
id : <?php echo $donnees['id']; ?><br />
Nom : <?php echo $donnees['nom']; ?><br />
Prénom : <?php echo $donnees['prénom']; ?><br />
Login : <?php echo $donnees['login']; ?> <br />
Password : <?php echo $donnees['pass']; ?> <br />
Société : <?php echo $donnees['société']; ?> <br />
Adresse mail : <?php echo $donnees['adresse']; ?> <br />
<?php if ( $donnees['type_de_compte'] = 1 ) ?>
        Type de compte : utilisateur
</p>
 
<?php
}
}
mysql_close(); // Déconnexion de MySQL
?>
</html>
Un warning s'affiche comme quoi l'index prenom (zone de texte) est indéfini...

Comment faire?

Merci d'avance...
djey08 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 24/05/2007, 09h54   #2
Modératrice
 
Avatar de Celira
 
Femme
Développeuse PHP/Java
Inscription : avril 2007
Messages : 3 686
Détails du profil
Informations personnelles :
Sexe : Femme
Âge : 27
Localisation : France

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

Informations forums :
Inscription : avril 2007
Messages : 3 686
Points : 5 451
Points : 5 451
Salut

Pour éviter les problèmes, avant la suppression tu peux tester l'existence de la variable $_POST['prenom'], en plus de celle du nom.

Ou alors donner un nom à ton bouton submit et vérifier qu'il existe.
Code php :
1
2
3
4
5
6
7
8
//...
<br><br><input type="submit" name="suppr" value="Supprimer"><br><br>
//...
 
if (isset($_POST['suppr'])){
   //recuperation de $_POST['nom'], $_POST['prenom']
  //requete DELETE ....
}
__________________
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)

Pour afficher votre code en couleurs : [CODE=php][/CODE] (bouton # de l'éditeur)
Celira est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 24/05/2007, 10h00   #3
Invité régulier
 
Inscription : avril 2007
Messages : 31
Détails du profil
Informations forums :
Inscription : avril 2007
Messages : 31
Points : 5
Points : 5
Ok, c'était sur le bouton que je devais faire le test...

Merci beaucoup Celira (encore une fois... )
djey08 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 24/05/2007, 10h05   #4
Modératrice
 
Avatar de Celira
 
Femme
Développeuse PHP/Java
Inscription : avril 2007
Messages : 3 686
Détails du profil
Informations personnelles :
Sexe : Femme
Âge : 27
Localisation : France

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

Informations forums :
Inscription : avril 2007
Messages : 3 686
Points : 5 451
Points : 5 451
De rien
Ce n'est pas obligatoirement le bouton, mais des fois c'est ce qu'il ya de plus pratique
En fait, ton problème venait du fait que tu recharges la page à chaque changement sur 'nom'. Donc tu peux avoir une valeur dans nom sans avoir soumis le reste du formulaire.
Le test du bouton résoud ça
__________________
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)

Pour afficher votre code en couleurs : [CODE=php][/CODE] (bouton # de l'éditeur)
Celira est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité Cette discussion est résolue.
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 03h37.


 
 
 
 
Partenaires

Hébergement Web