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

PHP & Base de données Discussion :

Hachage MD5 du mot de passe


Sujet :

PHP & Base de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Nouveau candidat au Club
    Inscrit en
    Décembre 2009
    Messages
    2
    Détails du profil
    Informations forums :
    Inscription : Décembre 2009
    Messages : 2
    Par défaut Hachage MD5 du mot de passe
    Bonjour,

    Je comprends pas pourquoi le user peut s'inscrire mais pas se loguer quand je laisse le cryptage md5, avec erreur : User/pwd invalide

    Si je supprime l' encryption md5, le user peut s' iscrire et se loguer

    Voila le code 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
     
     
    <?
    include "dbconfig.php";
     
    if(!empty($_POST['new_user'])){
      mysql_query("insert into users(username,userpwd) values('".$_POST['username']."','".md5($_POST['userpass'])."')") or die("&error=".mysql_error()."&");
      echo "&insertion=1&";
      exit;
    }
     
    if(!empty($_POST['username']) && !empty($_POST['userpass'])){
      $res=mysql_query("select username from users where username='".$_POST['username']."' and userpwd='".md5($_POST['userpass'])."'") or die("&error=".mysql_error()."&");		
      if(mysql_num_rows($res)==1){
    	$row=mysql_fetch_objec($res);
    	echo "&user=".$row->username."&";
      }
      else{
    	echo "&error=User/pwd invalide&";
      }
    } 
    else{
      echo "&error=Vous devez fournir le user et le pwd&";
    }
    ?>
    :


    Si quelqu'un a une suggestion , merci

  2. #2
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Par défaut
    Est-ce que tu n'utiliserais pas "userpass" pour désigner deux champs différents dans le meme formulaire ?
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  3. #3
    Nouveau candidat au Club
    Inscrit en
    Décembre 2009
    Messages
    2
    Détails du profil
    Informations forums :
    Inscription : Décembre 2009
    Messages : 2
    Par défaut
    IL n´y a que 2 champs dans le formulaire
    Cela fonctionne tres bien sans le md5 comme ceci :
    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
     
    <?
    include "dbconfig.php";
     
    if(!empty($_POST['new_user'])){
      mysql_query("insert into users(username,userpwd) values('".$_POST['username']."','".$_POST['userpass']."')") or die("&error=".mysql_error()."&");
      echo "&insertion=1&";
      exit;
    }
     
    if(!empty($_POST['username']) && !empty($_POST['userpass'])){
      $res=mysql_query("select username from users where username='".$_POST['username']."' and userpwd='".$_POST['userpass']."'") or die("&error=".mysql_error()."&");		
      if(mysql_num_rows($res)==1){
    	$row=mysql_fetch_objec($res);
    	echo "&user=".$row->username."&";
      }
      else{
    	echo "&error=User/pwd invalide&";
      }
    } 
    else{
      echo "&error=Vous devez fournir le user et le pwd&";
    }
    ?>

  4. #4
    Membre Expert
    Avatar de s.n.a.f.u
    Homme Profil pro
    Développeur Web
    Inscrit en
    Août 2006
    Messages
    2 760
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Août 2006
    Messages : 2 760
    Par défaut
    Le champs password est-il assez long pour recevoir le md5 ?
    Si non, il en stocke une version tronquée et PAF !

    Autre remarque : je ferais un index unique sur le login et n'utiliserais pas le mot de passe dans la clé primaire. Sinon, comment différencier deux utilisateurs qui ont le même login ?

  5. #5
    Membre éprouvé
    Inscrit en
    Décembre 2009
    Messages
    80
    Détails du profil
    Informations forums :
    Inscription : Décembre 2009
    Messages : 80
    Par défaut
    Petite remarque niveau sécurité sur ce petit script.
    Afin d'éviter toute injection SQL, il est fortement recommandé d'utiliser la fonction mysql_real_escape_string pour échapper les données récupérées par formulaire.

    A savoir par exemple remplacer la ligne :

    mysql_query("insert into users(username,userpwd) values('".$_POST['username']."','".md5($_POST['userpass'])."')") or die("&error=".mysql_error()."&");

    Par :

    mysql_query("insert into users(username,userpwd) values('".mysql_real_escape_string($_POST['username'])."','".md5($_POST['userpass'])."')") or die("&error=".mysql_error()."&");

  6. #6
    Membre Expert
    Avatar de aityahia
    Homme Profil pro
    CIEPTAL CARS SPA
    Inscrit en
    Mars 2006
    Messages
    1 938
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : Algérie

    Informations professionnelles :
    Activité : CIEPTAL CARS SPA
    Secteur : Transports

    Informations forums :
    Inscription : Mars 2006
    Messages : 1 938
    Par défaut
    salut

    le champs password doit avoir une longueur de 32 caractères au minimum.

Discussions similaires

  1. Réponses: 2
    Dernier message: 21/05/2013, 12h07
  2. Réponses: 6
    Dernier message: 04/03/2011, 12h12
  3. Hachage d'un mot de passe
    Par beabea dans le forum ASP.NET
    Réponses: 2
    Dernier message: 15/12/2007, 19h33
  4. Cacher encryptage mot de passe MD5
    Par cirdec dans le forum Général JavaScript
    Réponses: 6
    Dernier message: 21/02/2006, 20h10
  5. stockage de mot de passe. ASP contre md5
    Par christel1982 dans le forum ASP
    Réponses: 15
    Dernier message: 02/12/2005, 08h45

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