Rechercher : dans
Par :

Problème requête SQL et formulaire

Dernière réponse le 4 jun 2009 à 12:08:35 cayoul, le 3 jun 2009 à 00:30:14 
 Signaler ce message aux modérateurs

Bonjour,

C'est mon premier post sur un forum. Je demande l'aide de qui voudra bien parce que je bloque sur l'écriture d'un script php basique. J'ai un formulaire d'inscription sur index.php et je voudrais créer un site avec authentification et espace personnel (donc chaque utilisateur aurait son profil). Problème: je n'arrive même pas à écrire sur dans ma base de donnée à partir de mon formulaire. Je vous mets donc le formulaire en question, ainsi que la page inscription.php (appelé dans mon formulaire). Chose qui m'embête aussi, c'est que toutes les variables apparaissent dans l'URL comme si j'utilisais la méthode get. Est ce normal ? Merci d'avance de vos aides.

<form name="form1" method="post" action="inscription.php">
<tr>
<td>Nom</td>
<td><input type="text" name="Nom" id="Nom"></td>
</tr>
<tr>
<td>Prénom</td>
<td><input type="text" name="Prenom" id="Prenom"></td>
</tr>
<tr>
<td>Email</td>
<td><input type="text" name="Email" id="Email"></td>
</tr>
<tr>
<td>Mot de passe</td>
<td><input type="password" name="Mot_de_passe" id="Mot_de_passe"></td>
</tr>
<tr>
<td id="bouton" height="50" colspan="2">
<input type="submit" name="submit" value="S'inscrire">
</td>
</tr>
</form>

Et inscription.php:

<?php
//Si l'utilisateur a cliqué sur s'inscrire
if(isset($_POST['submit']))
{
//Se connecter à la base
mysql_connect("localhost","root","") or die (mysql_error());
mysql_select_db("abc");

//je déclare mes variables qui viennent du formulaire
$Nom=$_POST['Nom'];
$Prenom=$_POST['Prenom'];
$Email=$_POST['Email'];
$mdp5=md5($_POST['Mot_de_passe']);


$requete = mysql_query("INSERT INTO user(ID
, Nom
, Prenom
, Mot_de_passe
, Email )
VALUES(''
, '$Nom'
, '$Prenom'
, '$Mot_de_passe'
, '$Email'
)
");
$req = mysql_query($requete) or die (mysql_error());

//se déconnecter de MySQL
mysql_close();

}

?>

Configuration: Windows Vista, WAMP

1

Deeper, le 3 jun 2009 à 09:40:47

Salut,

qu'est-ce que ça fait exactement lorsque tu valides ?
comment sais-tu que ca ne se connecte pas à ta base de données ?

Répondre à Deeper

2

biboo, le 3 jun 2009 à 09:43:10

Essaie d'enlever les id, je ne vois pas à quoi ça sert si t'as déjà l'attribut "name".

Répondre à biboo

3

cayoul, le 3 jun 2009 à 12:49:13

Merci de vos aides. J'ai essayé d'enlever les id mais ça marche toujours pas. en gros quand je clique sur s'inscrire, ça m'ouvre une nouvelle page toute blanche et ça me passe toutes mes variables dans l'URL. En revanche ça n'écris pas dans ma base de données parce que je vérifie grâce à phpmyadmin. Par contre, quand je tappe ma requête sql directement dans phpmyadmin, là ça marche.

Alors je sais pas si c'est un problème de connexion à la base de donnée vu que j'ia mis un or die (mysql_error()), ça devrait pas me dire qu'il y a un eu problème lors de la connexion ?

Merci de continuer à m'aider svp

Répondre à cayoul

4

Alain_42, le 3 jun 2009 à 13:17:22

Salut,

rajoutes ça pour voir ce que tu reçoit:

if(isset($_POST['submit']))
{

//TEST valeurs postées:
echo '<pre>';
print_r($_POST);
echo '</pre>';

......


ensuite dans ta table user as tu bien mis ton champ ID en INT, autoincrement, et sans valeur par defaut ?

Répondre à Alain_42

5

cayoul, le 3 jun 2009 à 13:22:42

Oui j'ai bien mis ID en bigint autoincrémenté. J'ai essayé de mettre ce que tu m'as dis juste en dessous de mon isset mais ça ne change rien. j'ai toujours une page blanche qui s'ouvre avec les informations en URL.

Répondre à cayoul

6

NitroGen®, le 3 jun 2009 à 13:30:17

Essaie de mettre à la place de ceci dans ta condition if
if(isset($_POST['submit']))
{
}

Remplace ceci par :
if(isset($_POST['nom']) AND isset($_POST['prenom']) AND ...isset(tous les attributs name tu fais comme ceci))
{
//Ton script
}

Par contre dans ton formulaire change tous les name="Prenom" par name="prenom" car les variable n'accepte pas les majuscule pour les noms de variable enfin la première lettre je crois...

@++

Répondre à NitroGen®

7

Alain_42, le 3 jun 2009 à 13:34:58

change tous les name="Prenom" par name="prenom" car les variable n'accepte pas les majuscule pour les noms de variable enfin la première lettre je crois...


NON

on peut mettre une majuscule au début d'un nom de variable mais le fait de mettre en minuscule a l'avantage d'éviter de faire des erreurs

Répondre à Alain_42

8

NitroGen®, le 3 jun 2009 à 13:42:44

Je ne savais plus pour ma part je l'ai écrit toutes les variables en minuscule...
Je confond avec un autre language ...

Répondre à NitroGen®

9

cayoul, le 3 jun 2009 à 14:11:54

Voici mon nouveau fichier inscription.php:

<?php
//Si l'utilisateur a cliqué sur s'inscrire
if(isset($_POST['nom']) AND isset($_POST['prenom']) AND isset($_POST['mot_de_passe']) AND isset($_POST['mot_de_passe']) AND isset($_POST['email']))

{

//TEST valeurs postées:
echo '<pre>';
print_r($_POST);
echo '</pre>';

//Se connecter à la base
mysql_connect("localhost","root","") or die (mysql_error());
mysql_select_db("abc");

//je déclare mes variables qui viennent du formulaire
$nom=$_POST['nom'];
$prenom=$_POST['prenom'];
$email=$_POST['email'];
$mdp5=md5($_POST['mot_de_passe']);


$requete = mysql_query("INSERT INTO user(ID
, Nom
, Prenom
, Mot_de_passe
, Email )
VALUES(''
, '$nom'
, '$prenom'
, '$mot_de_passe'
, '$email'
)
");
$req = mysql_query($requete) or die (mysql_error());

//se déconnecter de MySQL
mysql_close();

}

?>

J'ai également fais les modifications dans le formulaire en mettant tout en minuscule.

Mais ça ne marche toujours pas. J'ai toujours une plage blanche qui s'ouvre avec en URL variable=valeur&....

Répondre à cayoul

10

NitroGen®, le 3 jun 2009 à 14:27:39

Par contre oui il y a sa mais aussi tu as ce problème: Je te conseille vivement lorsque tu déclare tes variable venant du formulaire de rajouter des paramètres pour sécuriser ta base de donnée. $prenom=mysql_real_escape_string(htmlspecialchars($_POST['pr­enom']));

Tu fais sa pour toutes les variables.

Répondre à NitroGen®

11

NitroGen®, le 3 jun 2009 à 14:28:51

Je vais faire ton petit code lol
attend quelques minutes.

Répondre à NitroGen®

12

Alain_42, le 3 jun 2009 à 14:33:29

Tu as une erreur au niveau mot de passe:

//je déclare mes variables qui viennent du formulaire
$nom=$_POST['nom'];
$prenom=$_POST['prenom'];
$email=$_POST['email'];
$mdp5=md5($_POST['mot_de_passe']);


$requete = mysql_query("INSERT INTO user(ID
, Nom
, Prenom
, Mot_de_passe
, Email )
VALUES(''
, '$nom'
, '$prenom'
, '$mot_de_passe'
, '$email'
)


tu n'utilises pas la même variable pour ta requette que celle reupérant la valeur postée par le formulaire

Répondre à Alain_42

13

cayoul, le 3 jun 2009 à 14:40:12

Merci pour vos remarques. Effectivement c'était à cause de ma variable mot de passe. je vais également profiter de NitroGen pour sécuriser ma base de données. Donc maintenant ça écris enfin dans ma base de donnée. Par contre sur la nouvelle page qui s'affiche il est écrit:

Array
(
[nom] => momo
[prenom] => momo
[email] => momo
[mot_de_passe] => momo
[submit] => S'inscrire
)

You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '1' at line 1

Qu'est ce que ça signifie svp ?

Répondre à cayoul

14

cayoul, le 3 jun 2009 à 14:43:54

En revanche en essayant de sécuriser ma base de données, ça marche plus. Voici ce que j'ai changé dans mon inscription.php:

//je déclare mes variables qui viennent du formulaire
$nom=mysql_real_escape_string(htmlspecialchars($_POST['no­m']);
$prenom=mysql_real_escape_string(htmlspecialchars($_POST[­'prenom']);
$email=mysql_real_escape_string(htmlspecialchars($_POST['­email']);
$mdp5==mysql_real_escape_string(htmlspecialchars(md5($_PO­ST['mot_de_passe']));

Il me dit qu'il y a une erreur dès la première ligne. J'ai repris lettre par lettre la proposition de NitroGen

Répondre à cayoul

15

cayoul, le 3 jun 2009 à 14:43:55

Array
(
[nom] => A
[prenom] => A
[email] => A
[mot_de_passe] => A
[submit] => S'inscrire
)

You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '1' at line 1

A chaque fois il me sort mes valeurs;

Je vous remets ma requête sql.

$requete = mysql_query("INSERT INTO user(ID
, Nom
, Prenom
, Mot_de_passe
, Email )
VALUES(''
, '$nom
, '$prenom'
, '$mdp5'
, '$email'
)
");
$req = mysql_query($requete) or die (mysql_error());

Répondre à cayoul

16

NitroGen®, le 3 jun 2009 à 14:53:51

Voila le travail par contre je ne peu pas faire le test je n'ai pas la BDD à toi de tester:
Formulaire:

<!-- Début formulaire -->
<form enctype="multipart/form-data" method="post" action="inscription.php">
<tr>
<td>Nom</td>
<td><input type="text" name="nom"></td>
</tr>
<tr>
<td>Prénom</td>
<td><input type="text" name="prenom"></td>
</tr>
<tr>
<td>Email</td>
<td><input type="text" name="email"></td>
</tr>
<tr>
<td>Mot de passe</td>
<td><input type="password" name="mot_de_passe"></td>
</tr>
<tr>
<td id="bouton" height="50" colspan="2">
<input type="submit" value="S'inscrire">
</td>
</tr>
</form>

<!-- Fin Formulaire -->







page "inscription.php"

<?php
//On vérifie que les variables existent
if (isset($_POST['nom']) AND isset($_POST['prenom']) AND isset($_POST['email']) AND isset($_POST['mot_de_passe']) )
{	
	//On vérifie que les variables contiennent quelques choses ...
	if($_POST['nom'] != NULL AND $_POST['prenom']!= NULL AND $_POST['email'] != NULL AND $_POST['mot_de_passe'] != NULL)
	{
		//Connexion à la BDD MySQL
		//Se connecter à la base
		mysql_connect("localhost","root","");
		mysql_select_db("abc");
		
		//je déclare mes variables qui viennent du formulaire
		$nom=mysql_real_escape_string(htmlspecialchars($_POST['nom']));
		$prenom=mysql_real_escape_string(htmlspecialchars($_POST['prenom']));
		$email=mysql_real_escape_string(htmlspecialchars($_POST['email']));
		$mdp5=mysql_real_escape_string(htmlspecialchars($_POST['mot_de_passe']));
		
		
		mysql_query("INSERT INTO user (ID, Nom, Prenom, Mot_de_passe, Email ) VALUES('', '$nom', '$prenom', '$mdp5', '$email') ") or die (mysql_error());

		//se déconnecter de MySQL
		mysql_close();
	
	echo "Inscription prise en compte, merci à vous.";
	}
}
else
{
echo "Désolée, Vous n'avez pas rempli tous les champs";
}
?>






Espérant que ce code marche car je viens de l'écrire sur le vif donc à toi de faire le test !.
@++

Répondre à NitroGen®

17

NitroGen®, le 3 jun 2009 à 14:59:01

Au faite pour ton erreur plus haut c'est en sécurisant les variables tu oublie une parenthèse en fermeture:

mysql_real_escape_string(htmlspecialchars($_POST[''])); 

Répondre à NitroGen®

18

cayoul, le 3 jun 2009 à 15:20:22

Merci énormèment NitroGen pour ton aide précieuse. J'ai la première pierre de mon édifice grâce à toi.

Répondre à cayoul

19

NitroGen®, le 3 jun 2009 à 15:26:53

Merci ce fut un plaisir de t'aider si besoin d'aide en programmation, tu c'est où demandé ;)

@++ Et bonne programmation à toi.

Répondre à NitroGen®