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 :

UPDATE mot de passe [MySQL]


Sujet :

PHP & Base de données

  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Août 2008
    Messages
    28
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2008
    Messages : 28
    Par défaut UPDATE mot de passe
    bonjour,
    j'ai rédigé grâce à votre aide un script d'envoi de mot de passe oublié avec une génération aléatoire;
    j'avais oublié un petit détail d'importance, c' est la modification du mot de passe dans la bdd au moment de l'envoi, puisque l'utilisateur en recevra un nouvellement généré
    j'ai donc rajouté la ligne (en gras) et j'ai un message d'erreur de syntaxe concernant une ) et je ne comprends pas où est l'erreur
    merci d'avance
    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
    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
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    <?php
    
    mysql_connect("localhost", "root", "");
    mysql_select_db("inscription");
       $result = mysql_query("
                        SELECT username, email
                        FROM site_user WHERE username = '" . $_POST["username"] . "'
                        OR email = '" . $_POST["email"] . "'
                   ");			  
    		
                // Si un enregistrement est trouvé
                     if(mysql_num_rows($result) > 0)
    				{
                       while($row = mysql_fetch_array($result))
    			  {                       
                             
    // ----------
    // Génération d'un mot de passe de 8 caractères alpha-numériques
    // ----------
    $tableau = array("0","1","2","3","4","5","6","7","8","9",
    "a","b","c","d","e","f","g","h","i","j","k","l","m","n",
    "o","p","q","r","s","t","u","v","w","x","y","z",
    "A","B","C","D","E","F","G","H","I","J","K","L","M","N",
    "O","P","Q","R","S","T","U","V","W","X","Y","Z");
    // ----------
    $valeurs_aleatoires = array_rand($tableau, 8);
    // ----------
    $mot_de_passe = "";
    
    foreach($valeurs_aleatoires as $i)
    {
         $mot_de_passe = $mot_de_passe . $tableau[$i];
    	 }
    	$updateSQL= "UPDATE site_user SET password WHERE username = '" . $_POST["username"] . "'
                        OR email = '" . $_POST["email"] . "'
                   ");	}		  					  					                   		   
    if (isset($_POST['envoye']) && $_SERVER['HTTP_REFERER'] == 'http://localhost/balthazar/accueil/contact.php')
    {
        /* Récupération des valeurs des champs du formulaire */
        if (get_magic_quotes_gpc())
        {
          
          $username = stripslashes(trim($_POST['username']));
          $email	= stripslashes(trim($_POST['email']));
        
        }
        else
        {    
          $username	    = trim($_POST['username']);
          $email	= trim($_POST['email']);
         
        }
     
        /* Expression régulière permettant de vérifier si le 
    	* format d'une adresse e-mail est correct */
        $regex_mail = '/^[-+.\w]{1,64}@[-.\w]{1,64}\.[-.\w]{2,6}$/i';
        
        /* Expression régulière permettant de vérifier qu'aucun 
        * en-tête n'est inséré dans nos champs */
        $regex_head = '/[\n\r]/';
     
        /* On vérifie que tous les champs sont remplis */
        if (empty($username)          
             || empty($email) )
               
        {
          $alert =  'Tous les champs doivent être renseignés';
        }
        /* On vérifie que le format de l'e-mail est correct */
        elseif (!preg_match($regex_mail, $email))
        {
          $alert =  'L\'adresse '.$email.' n\'est pas valide';
        }   
        
        /* Si aucun problème et aucun cookie créé, on construit le message et on envoie l'e-mail */
        elseif (!isset($_COOKIE['sent']))
        {
            /* Destinataire (votre adresse e-mail) */
            $to = 'martialb333@laposte.net';
     // Envoi du mail 
                                  $sujet = "envoi mot de passe oublié";
                                  $message = "Voici votre nouveau mot de passe :\n";                              $message .= "&password=" . $mot_de_passe;
                                  
                                  // Si une erreur survient
                                  if(!@mail($_POST["email"], $sujet, $message))
                                  {
                                  $alert = "Une erreur est survenue lors de l'envoi du mail <br />\n";
                                  }
                                  else
                                  {
                                       
                                       // Message de confirmation
                                       $alert = "Vous avez reçu votre nouveau mot de passe<br />\n";
                                       $alert .= "Un email vient de vous être envoyé";
    								   
    								  }
    								}
    								 /* On créé un cookie de courte durée (ici 120 secondes) pour éviter de  renvoyer un mail en rafraichissant la page */
                setcookie("sent", "1", time() + 120);
                
                /* On détruit la variable $_POST */
                unset($_POST);
            }
            else
            {
                $alert = 'Erreur d\'envoi de l\'e-mail';
            }
              
        }
        /* Cas où le cookie est créé et que la page est rafraichie, on détruit la variable $_POST */
        else
        {
            unset($_POST);
        }

  2. #2
    Membre Expert
    Avatar de supersnail
    Homme Profil pro
    Inscrit en
    Novembre 2006
    Messages
    1 719
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Novembre 2006
    Messages : 1 719
    Par défaut
    euh.. faut peut-être la valeur de password..

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Août 2008
    Messages
    28
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2008
    Messages : 28
    Par défaut
    euh... exact
    mais je suis un débutant qui ne parvient pas à transférer la valeur mot_de_passe (nouvellement créé par le tableau) vers la valeur password qui est celle de ma bdd
    "le nouveau mot de passe va updater le champ password" en langage php ?

    j'essaie également un autre script avec un formulaire html qui contient le pseudo et le mail, qui va vers un autre formulaire
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    "if isset $_pseudo ... echo votre password est :
    en passant par des formules mais j'ai des erreurs de syntaxes sur les variables

    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
     <?php mysql_connect("localhost", "root", "");
    mysql_select_db("inscription");
      $requet = "SELECT * FROM site_user";
    if($result = mysql_query($requet)) {
    while($ligne = mysql_fetch_row($result)) {
    $username = $ligne['username'];
    $email = $ligne['email'];
    $password = $ligne['password'];
    {
     
     if (isset ($_POST['username']) AND isset($_POST['email']))
    {
    $message ="votre mot de passe est '$password'";
    }
    ?>
    je suis entrain de regarder du coté javascript, quand l'utilsateur clique sur envoyer , apparaitrait la fenêtre votre mot de passe est
    est ce que c'est possible/recommandable ?
    dans quelle direction dois je chercher? je ne connais rien de rien à JS
    je suis sur Dreamweaver8, et l'option script m'offre des options que je ne comprends pas, ni comment rédiger la requête
    merci d'avance
    l'orthographe, ça va, c'est avec la grammaire que j'ai des soucis

  4. #4
    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
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
    // tu construis ton mot de passe
    foreach($valeurs_aleatoires as $i)  {
       $mot_de_passe = $mot_de_passe . $tableau[$i];
       }
     
    // tu proteges les données recus
    $username = mysql_real_escape($_POST["username"]);
    $email= mysql_real_escape($_POST["email"]);
     
    // tu fais ton update
    $updateSQL= "UPDATE site_user SET password='$mot_de_passe' WHERE username = '$username' OR email = '$email'";
    mysql_query($updateSQL);
    on n'introduit pas dans une requete SQL des données saisies par un utilisateur sans les avoir controlées.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  5. #5
    Membre averti
    Profil pro
    Inscrit en
    Août 2008
    Messages
    28
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2008
    Messages : 28
    Par défaut MERCI
    salut,
    et merci encore une fois de ton aide précieuse
    ce script est le dernier important avant de passer à la mise en route de mon site.toutes mes pages sont créées.
    je vais m'attaquer à cette étape maintenant.
    et comme je compare souvent la création de mon site à l'ascension de l'Everest, je dois être à peu près à 5000 mètres d'altitude

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. [phpMyAdmin] [phpMyAdmin] Problème mot de passe Root !
    Par StouffR dans le forum EDI, CMS, Outils, Scripts et API
    Réponses: 7
    Dernier message: 26/09/2014, 11h59
  2. [MySQL] update mot de passe php mysql
    Par Anandamine dans le forum PHP & Base de données
    Réponses: 1
    Dernier message: 08/06/2012, 17h08
  3. [VB6] [ADO] [Access] Changer le mot de passe
    Par dlpxlid dans le forum VB 6 et antérieur
    Réponses: 4
    Dernier message: 03/03/2003, 09h45
  4. Réccupération du mot de passe d'une connexion
    Par zinaif dans le forum Bases de données
    Réponses: 1
    Dernier message: 02/12/2002, 18h32
  5. Au sujet des mots de passe
    Par FranT dans le forum Langage
    Réponses: 6
    Dernier message: 17/09/2002, 22h16

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