Problème formulaire / php
Utilisateur anonyme
-
flokocha Messages postés 1510 Date d'inscription Statut Membre Dernière intervention -
flokocha Messages postés 1510 Date d'inscription Statut Membre Dernière intervention -
Salut !
Je me lance dans l'accès à des bases de données sous php; et là je bloque sur 1 truc.
J'ai une zone de liste avec différentes valeurs. Quand l'utilisateur clique sur une valeur de cette zone, un script est déclanché.
Le problème, c'est que le script ne se déclanche pas, ou en tout cas mal : à chaque clic, la page est mise à jour mais revient toujours à son état initial.
Pour être + clair, voici un lien : http://www.lepont.asso.fr/motDirecteur.php
Pour être plus complet, le code source du php :
<FORM METHOD = "Get" ACTION = "motDirecteur.php">
<SELECT NAME="cbochoisir" SIZE="1" ONCHANGE="form.submit()">
<OPTION VALUE="-1"> Sélectionner </OPTION>
<OPTION VALUE="0"> Tous les mots </OPTION>
<?
$connexion = mysql_pconnect("sql5","lepont","nZGSrtUo");
if ($connexion == FALSE) print("connexion pas OK !");
$acces = mysql_select_db("lepont",$connexion);
if ($acces == FALSE) print("acces base pas OK !");
$reqSQL = "SELECT * FROM mots WHERE Personne='directeur'";
$curseur = mysql_query($reqSQL, $connexion);
if ($curseur)
{ $enreg = mysql_fetch_object($curseur);
while ($enreg)
{
print("<OPTION Value=\"$enreg->num_mot\">$enreg->date_mot $enreg->intitule_mot </OPTION>");
$enreg = mysql_fetch_object($curseur);
}
}
else
{
print ("requete pas bonne !<BR>");
}
$reqSQL = "SELECT * FROM mots WHERE Personne='directeur'";
if ($cbochoisir >0)
{
$reqSQL= $reqSQL . " AND num_mot=$cbochoisir";
}
$curseur = mysql_query($reqSQL, $connexion);
if ($curseur)
{
$enreg = mysql_fetch_object($curseur);
while ($enreg)
{
print ("$enreg->date_mot $enreg->intitule_mot $enreg->mot<BR>");
$enreg =mySQL_fetch_object($curseur);
}
}
else
{
print ("requete pas bonne !<BR>");
}
mysql_close($connexion);
?>
</SELECT>
</FORM>
</body>
</html>
En espérant que quelqu'un puisse m'éclairer.
A oui, au fait, le script doit me faire afficher les infos de la base de données suivant l'enregistrement sélectionné...
Merci et @+
Je me lance dans l'accès à des bases de données sous php; et là je bloque sur 1 truc.
J'ai une zone de liste avec différentes valeurs. Quand l'utilisateur clique sur une valeur de cette zone, un script est déclanché.
Le problème, c'est que le script ne se déclanche pas, ou en tout cas mal : à chaque clic, la page est mise à jour mais revient toujours à son état initial.
Pour être + clair, voici un lien : http://www.lepont.asso.fr/motDirecteur.php
Pour être plus complet, le code source du php :
<FORM METHOD = "Get" ACTION = "motDirecteur.php">
<SELECT NAME="cbochoisir" SIZE="1" ONCHANGE="form.submit()">
<OPTION VALUE="-1"> Sélectionner </OPTION>
<OPTION VALUE="0"> Tous les mots </OPTION>
<?
$connexion = mysql_pconnect("sql5","lepont","nZGSrtUo");
if ($connexion == FALSE) print("connexion pas OK !");
$acces = mysql_select_db("lepont",$connexion);
if ($acces == FALSE) print("acces base pas OK !");
$reqSQL = "SELECT * FROM mots WHERE Personne='directeur'";
$curseur = mysql_query($reqSQL, $connexion);
if ($curseur)
{ $enreg = mysql_fetch_object($curseur);
while ($enreg)
{
print("<OPTION Value=\"$enreg->num_mot\">$enreg->date_mot $enreg->intitule_mot </OPTION>");
$enreg = mysql_fetch_object($curseur);
}
}
else
{
print ("requete pas bonne !<BR>");
}
$reqSQL = "SELECT * FROM mots WHERE Personne='directeur'";
if ($cbochoisir >0)
{
$reqSQL= $reqSQL . " AND num_mot=$cbochoisir";
}
$curseur = mysql_query($reqSQL, $connexion);
if ($curseur)
{
$enreg = mysql_fetch_object($curseur);
while ($enreg)
{
print ("$enreg->date_mot $enreg->intitule_mot $enreg->mot<BR>");
$enreg =mySQL_fetch_object($curseur);
}
}
else
{
print ("requete pas bonne !<BR>");
}
mysql_close($connexion);
?>
</SELECT>
</FORM>
</body>
</html>
En espérant que quelqu'un puisse m'éclairer.
A oui, au fait, le script doit me faire afficher les infos de la base de données suivant l'enregistrement sélectionné...
Merci et @+
A voir également:
- Problème formulaire / php
- Whatsapp formulaire opposition - Guide
- Formulaire de réclamation facebook - Guide
- Formulaire de reclamation instagram - Guide
- Easy php - Télécharger - Divers Web & Internet
- Confirmer le nouvel envoi du formulaire err_cache_miss - Forum Webmastering
24 réponses
Une erreur à corriger:
$reqSQL= $reqSQL . " AND num_mot=$cbochoisir";
doit devenir
$reqSQL= $reqSQL . " AND num_mot=".$cbochoisir;
A part ça, je te conseille de changer de mot de passe pour la connection à la base de donnée, car maintenant toute la planète le connait... ;)
hector
http://www.hec.unil.ch/infocentre
$reqSQL= $reqSQL . " AND num_mot=$cbochoisir";
doit devenir
$reqSQL= $reqSQL . " AND num_mot=".$cbochoisir;
A part ça, je te conseille de changer de mot de passe pour la connection à la base de donnée, car maintenant toute la planète le connait... ;)
hector
http://www.hec.unil.ch/infocentre
Merci de m'avoir répondu, mais là c'est pire, il me fout un message d'erreur.
Pour le mot de passe, tu m'étonnes, trop con...
En fait, j'essayé un peu tout, et à bout de nerf, je me suis dit "laisse tomber, ça fait 2 heures que tu es dessus, vas poser la question, il y a qqc qui doit sauter aux yeux". Et j'ai fait un c/c de tout le merdier sans réfléchir...
Mais merci !
@+
Pour le mot de passe, tu m'étonnes, trop con...
En fait, j'essayé un peu tout, et à bout de nerf, je me suis dit "laisse tomber, ça fait 2 heures que tu es dessus, vas poser la question, il y a qqc qui doit sauter aux yeux". Et j'ai fait un c/c de tout le merdier sans réfléchir...
Mais merci !
@+
Si tu utilises une version de PHP qui est la 4.2 ou plus récente, tu dois récupérer les résultats de ton formulaire avec la variable d'environnement $_GET["nomdelavariable"].
.::: "A trop vouloir feindre de faire fi, on finit
par faire fi de vouloir feindre." :::.
.::: "A trop vouloir feindre de faire fi, on finit
par faire fi de vouloir feindre." :::.
Merci, mais je sais que c'est la version 4 et/ou 5.
En tous cas, j'ai essayé, et c'est exactement la même chose.
Qq a une idée ???
En tous cas, j'ai essayé, et c'est exactement la même chose.
Qq a une idée ???
Vous n’avez pas trouvé la réponse que vous recherchez ?
Posez votre question
Tu as un message d'erreur? Si oui lequel?
.::: "A trop vouloir feindre de faire fi, on finit
par faire fi de vouloir feindre." :::.
.::: "A trop vouloir feindre de faire fi, on finit
par faire fi de vouloir feindre." :::.
Non, je n'ai pas de message d'erreur, mais vas voir sur le site ce que ça fait : http://www.lepont.asso.fr/motDirecteur.php
Tu vois, la zone de liste se reinitialise à chaque fois et ne me fait pas afficher les résultats.
Ca me prendre la tête !
Tu vois, la zone de liste se reinitialise à chaque fois et ne me fait pas afficher les résultats.
Ca me prendre la tête !
Et tu as bien rajouté ça:
$cbochoisir = $_GET["cbochoisir"]; ?
C'est bizarre...
Essaie ça pour voir:
$reqSQL= $reqSQL . " AND num_mot='".$cbochoisir."'";
.::: "A trop vouloir feindre de faire fi, on finit
par faire fi de vouloir feindre." :::.
$cbochoisir = $_GET["cbochoisir"]; ?
C'est bizarre...
Essaie ça pour voir:
$reqSQL= $reqSQL . " AND num_mot='".$cbochoisir."'";
.::: "A trop vouloir feindre de faire fi, on finit
par faire fi de vouloir feindre." :::.
Ça n'apparaît pas très clairement à l'écran donc je rajoute des espaces pour que tu voies bien:
$reqSQL= $reqSQL . " AND num_mot=' ".$cbochoisir." ' ";
En gros tu mets le contenu de $cbochoisir entre quotes simples.
.::: "A trop vouloir feindre de faire fi, on finit
par faire fi de vouloir feindre." :::.
$reqSQL= $reqSQL . " AND num_mot=' ".$cbochoisir." ' ";
En gros tu mets le contenu de $cbochoisir entre quotes simples.
.::: "A trop vouloir feindre de faire fi, on finit
par faire fi de vouloir feindre." :::.
Là je suis à court d'idées... Désolé :(
.::: "A trop vouloir feindre de faire fi, on finit
par faire fi de vouloir feindre." :::.
.::: "A trop vouloir feindre de faire fi, on finit
par faire fi de vouloir feindre." :::.
C'est pas grave, merci quand même.
Je remets le code, au cas où :
Je remets le code, au cas où :
<FORM METHOD = "Get" ACTION = "motDirecteur.php"> <SELECT NAME="cbochoisir" SIZE="1" ONCHANGE="form.submit()"> <OPTION VALUE="-1"> Sélectionner </OPTION> <OPTION VALUE="0"> Tous les mots </OPTION> <? $connexion = mysql_pconnect("xx","xx","xx"); if ($connexion == FALSE) print("connexion pas OK !"); $acces = mysql_select_db("xx",$connexion); if ($acces == FALSE) print("acces base pas OK !"); $reqSQL = "SELECT * FROM mots WHERE Personne='directeur'"; $curseur = mysql_query($reqSQL, $connexion); if ($curseur) { $enreg = mysql_fetch_object($curseur); while ($enreg) { print("<OPTION Value=\"$enreg->num_mot\">$enreg->date_mot $enreg->intitule_mot </OPTION>"); $enreg = mysql_fetch_object($curseur); } } else { print ("requete pas bonne !<BR>"); } $reqSQL = "SELECT * FROM mots WHERE Personne='directeur'"; if (cbochoisir >0) { $reqSQL= $reqSQL . " AND num_mot='".$cbochoisir."'"; } $curseur = mysql_query($reqSQL, $connexion); if ($curseur) { $enreg = mysql_fetch_object($curseur); while ($enreg) { print ("$enreg->date_mot $enreg->intitule_mot $enreg->mot<BR>"); $enreg =mySQL_fetch_object($curseur); } } else { print ("requete pas bonne !<BR>"); } mysql_close($connexion); ?> </SELECT> </FORM>
fait un echo $curseur pour verifier que la requete marche bien
sinon essaie en la tapant entierement
$reqSQL="SELECT * FROM mots WHERE Personne='directeur' and num_mot = $cbochoisir";
sinon essaie en la tapant entierement
$reqSQL="SELECT * FROM mots WHERE Personne='directeur' and num_mot = $cbochoisir";
Salut et merci, mais non, cette fois j'ai un message d'erreur : Parse error: parse error, unexpected T_STRING in /home/lepont/www/motDirecteur.php on line 47
(la ligne 47 correspond à la ligne de la requête)
Et le echo ne donne rien (même avant d'avoir changé la requête).
(la ligne 47 correspond à la ligne de la requête)
Et le echo ne donne rien (même avant d'avoir changé la requête).
Si tu mets les tags
</SELECT>
</FORM>
après le dernier </OPTION> (et non pas à la fin de ton script !), ça devrait aller mieux!
Tu peux aussi ajouter des or die (mysql_error()); après des fonctions propres à mysql, comme ça tu auras des messages d'erreur si ça marche pas.
p.ex:
$curseur = mysql_query($reqSQL, $connexion);
devient
$curseur = mysql_query($reqSQL, $connexion) or die (mysql_error());
hector
http://www.hec.unil.ch/infocentre
</SELECT>
</FORM>
après le dernier </OPTION> (et non pas à la fin de ton script !), ça devrait aller mieux!
Tu peux aussi ajouter des or die (mysql_error()); après des fonctions propres à mysql, comme ça tu auras des messages d'erreur si ça marche pas.
p.ex:
$curseur = mysql_query($reqSQL, $connexion);
devient
$curseur = mysql_query($reqSQL, $connexion) or die (mysql_error());
hector
http://www.hec.unil.ch/infocentre
NoSFe : ça ne change rien.
hector : le or die ne change rien, et le </select> </form> non plus, au contraire : http://www.lepont.asso.fr/motDirecteur.php
De toute façon l'accès à la base est correct car dans la liste les valeurs sont bien ajoutées (1ère partie du script).
Merci tout de même à vous !
hector : le or die ne change rien, et le </select> </form> non plus, au contraire : http://www.lepont.asso.fr/motDirecteur.php
De toute façon l'accès à la base est correct car dans la liste les valeurs sont bien ajoutées (1ère partie du script).
Merci tout de même à vous !
Ah non mais là tu l'as placé trop tôt ton </select></form> !
:D
Il faut que tu les mettes juste après ce morceau de code:
.::: "A trop vouloir feindre de faire fi, on finit
par faire fi de vouloir feindre." :::.
:D
Il faut que tu les mettes juste après ce morceau de code:
while ($enreg) { print("<OPTION Value=\"$enreg->num_mot\">$enreg->date_mot $enreg->intitule_mot </OPTION>"); $enreg = mysql_fetch_object($curseur); }
.::: "A trop vouloir feindre de faire fi, on finit
par faire fi de vouloir feindre." :::.
J'ai refermé le code php avec les sin select et form et réouvert juste derrière.
Le formulaire est rafraichi tout de même http://www.lepont.asso.fr/motDirecteur.php
Le formulaire est rafraichi tout de même http://www.lepont.asso.fr/motDirecteur.php
Donc, voici ce que j'ai http://www.lepont.asso.fr/motDirecteur.php
avec ce code
Là il faut que je m'absente 1 ou 2 heures, mais votre aide est la bienvenue !
Merci encore et à tout'.
avec ce code
<FORM METHOD = "Get" ACTION = "motDirecteur.php"> <SELECT NAME="cbochoisir" SIZE="1" ONCHANGE="form.submit()"> <OPTION VALUE="-1"> Sélectionner </OPTION> <OPTION VALUE="0"> Tous les mots </OPTION> <? $connexion = mysql_pconnect("sql5","lepont","ghdhrfq"); if ($connexion == FALSE) print("connexion pas OK !"); $acces = mysql_select_db("lepont",$connexion); if ($acces == FALSE) print("acces base pas OK !"); $reqSQL = "SELECT * FROM mots WHERE Personne='directeur'"; $curseur = mysql_query($reqSQL, $connexion); if ($curseur) { $enreg = mysql_fetch_object($curseur); while ($enreg) { print("<OPTION Value=\"$enreg->num_mot\">$enreg->date_mot $enreg->intitule_mot </OPTION>"); $enreg = mysql_fetch_object($curseur); } } else { print ("requete pas bonne !<BR>"); } ?> </SELECT> </FORM> <? $reqSQL="SELECT * FROM mots WHERE Personne='directeur'"; if ($cbochoisir >0) { $reqSQL="SELECT * FROM mots WHERE Personne='directeur' "; } echo $reqSQL; $curseur = mysql_query($reqSQL, $connexion) or die (mysql_error()); if ($curseur) { $enreg = mysql_fetch_object($curseur); while ($enreg) { print ("$enreg->date_mot $enreg->intitule_mot $enreg->mot<BR>"); $enreg =mySQL_fetch_object($curseur); } } else { print ("requete pas bonne !<BR>"); } mysql_close($connexion); ?>
Là il faut que je m'absente 1 ou 2 heures, mais votre aide est la bienvenue !
Merci encore et à tout'.