[PHP] [WEB] Problème base de données

Résolu/Fermé
Anonymous - Modifié par NHenry le 20/06/2015 à 20:04
jordane45 Messages postés 38145 Date d'inscription mercredi 22 octobre 2003 Statut Modérateur Dernière intervention 25 avril 2024 - 21 juin 2015 à 14:48
Bonjour,
j'ai commencer la création de mon site web en HTML et j'ai décidé d'y intégrer mon espace membre. Donc sur YouTube je suis en train de suivre un tuto (PrimFX) mais j'ai un problème au moment du test pour inscrire un compte. Je remplis tous les champs jusqu'à avoir comme message: "Votre compte à bien été créé !" mais dans ma base de données je n'ai rien et donc je ne peux pas tester le module de connexion...
Voilà le code de mon module d'inscription (complet):
<?php

$bdd = new PDO('mysql:host=127.0.0.1;dbname=espace_membre', 'root', '');

if(isset($_POST['forminscription']))
{
 $pseudo = htmlspecialchars($_POST['pseudo']);
 $mail = htmlspecialchars($_POST['mail']);
 $mail2 = htmlspecialchars($_POST['mail2']);
 $mdp = sha1($_POST['mdp']);
 $mdp2 = sha1($_POST['mdp2']);

 if(!empty($_POST['pseudo']) AND !empty($_POST['mail']) AND !empty($_POST['mail2']) AND !empty($_POST['mdp']) AND !empty($_POST['mdp2']))
 {
  $pseudolenght = strlen($pseudo);
  if($pseudolenght <= 255)
  {
   if($mail == $mail2)
   { 

    if(filter_var($mail, FILTER_VALIDATE_EMAIL))
    {
     $reqmail= $bdd->prepare("SELECT * FROM membres WHERE mail = ?");
     $reqmail->execute(array($mail));
     $mailexist = $reqmail->rowCount(); 
     if($mailexist == 0)
     {
      if($mdp == $mdp2)
      {
       $insertmbr = $bdd->prepare("INSERT INTO membres(pseudo, mail, motdepase) VALUES(?, ?, ?) ");
       $insertmbr->execute(array($pseudo, $mail, $mdp));
       $erreur = "Votre compte a bien été créé !";
      }
      else
      {
       $erreur = "Les mots de passes ne correspondent pas !";
      }
     }
    }
    else
    {
     $erreur = "L'adresse mail entrée est déjà utilisée !";
    }
   }
    else
    {
     $erreur = "Les adresses e-mail ne correspondent pas !";
    }
  }
  else
  {
   $erreur = "Votre pseudo est trop long !";
  }
 }
 else
 {
  $erreur = "Tous les champs doivent être remplis !";
 }
}

?>


Désolé c'est pas très compréhensible mais bon...

4 réponses

jordane45 Messages postés 38145 Date d'inscription mercredi 22 octobre 2003 Statut Modérateur Dernière intervention 25 avril 2024 4 650
Modifié par jordane45 le 20/06/2015 à 20:33
Bonjour,

Commence par mettre du TRY/CATCH sur l'execution de tes requêtes pour voir s'il n'y a pas un souci.
Par exemple :

try{
   $sql = "INSERT INTO membres  (pseudo, mail, motdepase) VALUES(?, ?, ?)";
   $params = array($pseudo, $mail, $mdp);
   $insertmbr = $bdd->prepare($sql);
   $insertmbr->execute($params);
}catch(Exception $e) {
    echo "<br>ERREUR ! ".$e->getMessage()."<br>";
    echo "<br>params : <br>";
    print_r($params);
}
$erreur = "Votre compte a bien été créé !";


Cordialement,
Jordane
1
Bonjour jordane45 où dois-je mettre ce code ?
0
jordane45 Messages postés 38145 Date d'inscription mercredi 22 octobre 2003 Statut Modérateur Dernière intervention 25 avril 2024 4 650
20 juin 2015 à 21:56
A la place de celui contenu dans ton IF
 if($mdp == $mdp2)
      {
       $insertmbr = $bdd->prepare("INSERT INTO membres(pseudo, mail, motdepase) VALUES(?, ?, ?) ");
       $insertmbr->execute(array($pseudo, $mail, $mdp));
       $erreur = "Votre compte a bien été créé !";
      }

A transformer en :
 if($mdp == $mdp2)  {
       try{
          $sql = "INSERT INTO membres  (pseudo, mail, motdepase) VALUES(?, ?, ?)";
          $params = array($pseudo, $mail, $mdp);
          $insertmbr = $bdd->prepare($sql);
          $insertmbr->execute($params);
       }catch(Exception $e) {
           echo "<br>ERREUR ! ".$e->getMessage()."<br>";
           echo "<br>params : <br>";
           print_r($params);
      }
       $erreur = "Votre compte a bien été créé !";
   }
1
Bonjour j'obtiens le même résultat avec votre code et avec le mien: rien dans ma base donc impossible de me connecter...
0
jordane45 Messages postés 38145 Date d'inscription mercredi 22 octobre 2003 Statut Modérateur Dernière intervention 25 avril 2024 4 650
21 juin 2015 à 11:16
C'est en effet peut être un souci de connexion.

Essayes ça :
<?php
// Reporte toutes les erreurs PHP (Voir l'historique des modifications)
error_reporting(E_ALL);

//-------------------------------------------------------------------------------------------//
// Connexion à la BDD*
//-------------------------------------------------------------------------------------------//
$serveur = "127.0.0.1";
$db_name = "espace_membre'";
$user = "root";
$password = "";
$dsn = "mysql:host=".$serveur.";dbname=".$db_name;

try {
    $bdd = new PDO($dsn, $user, $password, array(PDO::ATTR_ERRMODE => PDO::ERRMODE_WARNING));
} catch (PDOException $e) {
    echo 'Echec de la connexion : ' . $e->getMessage();
    exit;
}
//-------------------------------------------------------------------------------------------//

//Récupération des variables
 $pseudo = !empty($_POST['pseudo']) ? htmlspecialchars($_POST['pseudo']) :NULL;
 $mail = !empty($_POST['mail'])? htmlspecialchars($_POST['mail']) : NULL;
 $mail2 = !empty($_POST['mail2']) ? htmlspecialchars($_POST['mail2']) :NULL;
 $mdp = !empty($_POST['mdp']) ? sha1($_POST['mdp']):NULL;
 $mdp2 = !empty($_POST['mdp2']) ? sha1($_POST['mdp2']):NULL;
 
//traitement du submit
if(isset($_POST['forminscription'])){

 if($pseudo && $mail && $mail2 && $mdp && $mdp2) {
  $pseudolenght = strlen($pseudo);
  if($pseudolenght <= 255){
   if($mail == $mail2){ 
    if(filter_var($mail, FILTER_VALIDATE_EMAIL)){
		 $sql1 = "SELECT * FROM membres WHERE mail = ?";	 
     $reqmail= $bdd->prepare($sql1);
     $reqmail->execute(array($mail));
     $mailexist = $reqmail->rowCount(); 
     if($mailexist == 0){
      if($mdp == $mdp2){
       try{
        $sql = "INSERT INTO membres  (pseudo, mail, motdepase) VALUES(?, ?, ?)";
        $params = array($pseudo, $mail, $mdp);
        $insertmbr = $bdd->prepare($sql);
        $insertmbr->execute($params);
      }catch(Exception $e) {
        echo "<br>ERREUR ! ".$e->getMessage()."<br>";
        echo "<br>params : <br>";
        print_r($params);
      }
      $erreur = "Votre compte a bien été créé !";
     } else{
       $erreur = "Les mots de passes ne correspondent pas !";
     }
    }
   } else {
     $erreur = "L'adresse mail entrée est déjà utilisée !";
    }
  }else {
     $erreur = "Les adresses e-mail ne correspondent pas !";
    }
 }else {
   $erreur = "Votre pseudo est trop long !";
  }
 }else{
  $erreur = "Tous les champs doivent être remplis !";
 }
}

?>

1
Je n'ai pas compris ce que je dois mettre ici:
// Reporte toutes les erreurs PHP (Voir l'historique des modifications)
0
jordane45 Messages postés 38145 Date d'inscription mercredi 22 octobre 2003 Statut Modérateur Dernière intervention 25 avril 2024 4 650 > Anonymous
21 juin 2015 à 11:31
Tu as juste à prendre tout le code que je t'ai donné ... et à remplacer le tient.
Après.. tu le testes ..et tu vois ce que ça donne.
0
Voilà le résultat:
http://bit.ly/1QK7lAG
0
J'ai enfin réussi je ne sais même pas comment j'ai refait la manipulation de ce tutoriel:
https://www.youtube.com/watch?v=s7qtAnH5YkY
Merci quand même jordane45 si je n'avais pas eu d'aide j'aurai sans doute laisser mon projet à l'abandon.
Merci !
0
jordane45 Messages postés 38145 Date d'inscription mercredi 22 octobre 2003 Statut Modérateur Dernière intervention 25 avril 2024 4 650
21 juin 2015 à 14:48
Les messages d'erreurs sont assez clair pour comprendre où est le souci...
Dans la requête... un champ de ta BDD n'a pas le bon nom ou n'existe pas.
0