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 12/01/2007, 17h08   #1
Invité de passage
 
Inscription : novembre 2006
Messages : 51
Détails du profil
Informations forums :
Inscription : novembre 2006
Messages : 51
Points : 2
Points : 2
Par défaut Vérifier les données dans le formulaires HTML, lié à la base

Bonjour,

J'ai écrit un script de traitement qui récupére des données du formulaire contenant les champs de texte, (nom, prenom, et mot de pass) et qui vérifie l'idenfitication de l'utilisateur dans ma base. J'affiche un message OK si les trois champs sont bons, sinon afficher un message d'erreur.

Je ne sais pas où sont des fautes dans mon script, il s'affiche tjs erreur, pourtant j'ai bien rempli les champs. Merci
Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
 
$connexion=mysql_connect('localhost', 'root') or die ("connextion au serveur impossible");
$db=mysql_select_db('defi', $connexion) or die ("sélection de la base impossible");
$nom='';
$prenom='';
$motdepasse='';
 
$req="SELECT * FROM identification WHERE nom='$nom' AND prenom='$prenom' AND pass='$motdepasse'";
$res=mysql_query($req);
$ligne=mysql_fetch_array($res);
 
 
$nom=$_POST['nom'];
$prenom=$_POST['prenom'];
$motdepasse=$_POST['motdepasse'];
 
if($nom==$ligne['nom'] && $prenom==$ligne['prenom'] && $motdepasse==$ligne['motdepasse'])
 
{echo "Bienvenu $ligne[nom] $ligne[prenom] !";}
 
else{ echo " erreur";}
ciel65 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 12/01/2007, 17h27   #2
Modérateur
 
Avatar de Nesmontou
 
Homme Benjamin PREVOT
Architecte de système d'information
Inscription : septembre 2004
Messages : 1 570
Détails du profil
Informations personnelles :
Nom : Homme Benjamin PREVOT
Âge : 30
Localisation : France, Nord (Nord Pas de Calais)

Informations professionnelles :
Activité : Architecte de système d'information
Secteur : Finance

Informations forums :
Inscription : septembre 2004
Messages : 1 570
Points : 2 506
Points : 2 506
Salut, dans ton if, il me semble que tu devrais mettre
Code :
$motdepasse==$ligne['pass']
(d'après ce que tu as écrit dans ta requête)

Sinon, petite remarque en passant, ta construction de requête n'est pas très sécurisée, elle permet de faire de l'injection SQL ; tu peux jeter un oeil ici : http://php.developpez.com/cours/#securite

Bon développement
__________________
Si vous ne pouvez expliquer un concept à un enfant de six ans, c'est que vous ne le comprenez pas complètement. Albert EINSTEIN

F.A.Q. : Java, PHP, (X)HTML / CSS

N'oubliez pas de cliquer sur le bouton Résolu en bas de page quand vous avez obtenu une solution à votre problème
Nesmontou est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 12/01/2007, 17h36   #3
Invité de passage
 
Inscription : novembre 2006
Messages : 51
Détails du profil
Informations forums :
Inscription : novembre 2006
Messages : 51
Points : 2
Points : 2
j'ai mis "pass", mais rien a changé.
ciel65 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 12/01/2007, 17h43   #4
Membre éprouvé
 
Inscription : février 2004
Messages : 456
Détails du profil
Informations forums :
Inscription : février 2004
Messages : 456
Points : 428
Points : 428
Salut,

ya aussi la requête à corriger, pour l'instant elle sélectionne les lignes dont le nom, prénom et mdpasse sont vides.

Tu dois faire:
Code :
1
2
3
4
5
$nom=$_POST['nom'];
$prenom=$_POST['prenom'];
$motdepasse=$_POST['motdepasse'];
 
$req="SELECT * FROM identification WHERE nom='$nom' AND prenom='$prenom' AND pass='$motdepasse'";
Puis tu testes si la requête te retourne des lignes.

Mais surtout, va voir le lien que Nesmontou t'as donné!
billoum est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 19h33.


 
 
 
 
Partenaires

Hébergement Web