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 :

Insertion manquante [MySQL]


Sujet :

PHP & Base de données

  1. #1
    Nouveau Candidat au Club
    Homme Profil pro
    Webmaster
    Inscrit en
    Mai 2015
    Messages
    6
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 28
    Localisation : France, Seine et Marne (Île de France)

    Informations professionnelles :
    Activité : Webmaster

    Informations forums :
    Inscription : Mai 2015
    Messages : 6
    Points : 1
    Points
    1
    Par défaut Insertion manquante
    Bonjour,

    Je suis en train de coder un site, et j'en suis actuellement au système de connexion inscription, cependant, j'ai un problème :

    Au niveau de la connexion, tout fonctionne aux petits oignons, mais il n'en est pas de même pour l'inscription : tout roule normalement jusqu'à la fin, sauf que lors de l'insertion des valeurs dans la base de données, ça veut pas. Je précise que je n'ai aucune erreur.

    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
    115
    116
    117
    118
    119
    120
    121
    122
    123
    124
    125
    126
    127
    128
    129
    130
    131
    132
    133
    134
    135
    136
    137
    138
    139
    140
    141
    142
    143
    144
    145
    146
    147
    148
    149
    150
    151
    152
    153
    154
    155
    156
    157
    158
    159
    160
    161
    <?php include('includes/sql.php');
    if (isset($_SESSION['id'])) {
        session_destroy();
        header ('Location:index.php');
    }
    ?>
    <!DOCTYPE html>
    <html lang="en">
    <head>
        <title>YgoShare | Connexion / Inscription</title>
        <meta charset="utf-8">
        <meta name = "format-detection" content = "telephone=no" />
        <link rel="stylesheet" href="http://yui.yahooapis.com/pure/0.6.0/pure-min.css">
        <link rel="icon" href="images/favicon.ico">
        <link rel="shortcut icon" href="images/favicon.ico" />
        <link rel="stylesheet" href="css/contact-form.css">
        <link rel="stylesheet" href="css/style.css">
        <script src="js/jquery.js"></script>
        <script src="js/jquery-migrate-1.1.1.js"></script>
        <script src="js/jquery.easing.1.3.js"></script>
        <script src="js/script.js"></script>
        <script src="js/superfish.js"></script>
        <script src="js/jquery.equalheights.js"></script>
        <script src="js/jquery.mobilemenu.js"></script>
        <script src="js/tmStickUp.js"></script>
        <script src="js/TMForm.js"></script>
        <script src="js/modal.js"></script>
        <script src="js/jquery.ui.totop.js"></script>
        <script>
            $(window).load(function(){
                $().UItoTop({ easingType: 'easeOutQuart' });
            });
        </script>
        <!--[if lt IE 8]>
        <div style=' clear: both; text-align:center; position: relative;'>
            <a href="http://windows.microsoft.com/en-US/internet-explorer/products/ie/home?ocid=ie6_countdown_bannercode">
                <img src="http://storage.ie6countdown.com/assets/100/images/banners/warning_bar_0000_us.jpg" border="0" height="42" width="820" alt="You are using an outdated browser. For a faster, safer browsing experience, upgrade for free today." />
            </a>
        </div>
        <![endif]-->
        <!--[if lt IE 9]>
        <script src="js/html5shiv.js"></script>
        <link rel="stylesheet" media="screen" href="css/ie.css">
        <![endif]-->
    </head>
     
    <body>
    <div class="main">
     <?php include('includes/header.php'); ?>
        <!--=====================
                  Content
        ======================-->
        <section id="content"><div class="ic">Page de connexion o/.</div>
            <div class="container">
                <div class="row">
                    <?php
                    if(isset($_POST['login'])) {
                        $pseudo = htmlspecialchars(stripcslashes($_POST['pseudo']));
                        $pass = md5(htmlspecialchars(stripcslashes($_POST['pass'])));
                        $query = $sql->prepare("SELECT * FROM users WHERE pseudo LIKE :pseudo AND pass LIKE :pass");
                        $query->execute(array(
                            ':pass' => $pass,
                            ':pseudo' => $pseudo
                        ));
                        $rows = $query->rowCount();
                        if($rows == 1) {
                            while($req = $query->fetch()) {
                                $_SESSION['pseudo'] = $req['pseudo'];
                                $_SESSION['id'] = $req['id'];
                                $_SESSION['login'] = 0;
                                echo "<script type='text/javascript'>document.location.replace('index.php');</script>";
                            }
     
                        } else { echo "Ce couple pseudo/mot de passe n'est pas valable.";}
     
                    } elseif(isset($_POST['register'])) {
                        if ($_POST['pseudo'] != "") {
                            $pseudo = htmlspecialchars(stripcslashes($_POST['pseudo']));
                            if($_POST['pass'] != "") {
                                $pass = md5(htmlspecialchars(stripcslashes($_POST['pass'])));
                                if(filter_var($_POST['mail'], FILTER_VALIDATE_EMAIL)) {
                                    $mail = htmlspecialchars(stripcslashes($_POST['mail']));
                                    $query = $sql->prepare("SELECT * FROM users WHERE pseudo LIKE :pseudo OR mail LIKE :mail");
                                    $query->execute(array(
                                        ":pseudo" => $pseudo,
                                        ":mail" => $mail
                                    ));
                                    $rows = $query->rowCount();
                                    $query3 = $sql->query("SELECT * FROM users");
                                    while($req2 = $query3->fetch()) {
                                        $id = $req2['id'];
                                        $id++;
                                    }
                                    if($rows == 0) {
                                        $date = date('Y-m-d');
                                        $tquery = "INSERT INTO users (id, pseudo, pass, mail, rang, avatar, join) VALUES('', :pseudo, :pass, :mail, :rang, :avatar, :join)";
                                        $query2 = $sql->prepare($tquery);
                                        $array = array(
                                            ":pseudo" => $pseudo,
                                            ":pass" => $pass,
                                            ":mail" => $mail,
                                            ":rang" => "Membre",
                                            ":avatar" => "https://cdn3.iconfinder.com/data/icons/softwaredemo/PNG/256x256/User1.png",
                                            ":join" => $date
                                        );
                                        $query2->execute($array);
                                        echo "<pre>";
                                        print_r($array);
                                        echo "</pre>";
                                        $rows2 = $query2->rowCount();
                                        echo "$rows2 ligne insérée.";
                                        echo "<br />Enregistrement réussi ! Vous pouvez vous connecter <b><a href='login.php'>en cliquant ici.</a></b>";
                                    } else {echo "<br />L'adresse email ou le pseudonyme est déjà utilisé, désolé ^^'";}
                                } else {echo "<br />Veuillez entrer une email valable !<br />";}
                            } else {echo "<br />Veuillez entrer un mot de passe !<br />";}
                        } else {echo "<br />Veuillez entrer un pseudonyme !<br />";}
     
                    } else {
                    ?>
                    <div class="grid_5">
                        <h4>Se connecter</h4>
                        <!-- Formulaires -->
                        <form method="post" class="pure-form">
                                <input type="text" name="pseudo" placeholder="Pseudonyme" value="" style="margin-right:15px;"   />
                                <input type="password" name="pass" placeholder="Mot de passe" value="" style="margin-right:15px;"  />
                                <button type="submit" class="pure-button pure-button-primary" style="margin-top:15px;display:block;margin-left:25%" name="login">Se connecter</button>
                        </form>
     
                    </div>
     
                    <div class="grid_6 preffix_1">
                        <h4>S'inscrire</h4>
                        <form method="post" class="pure-form pure-form-aligned">
                            <div class="pure-control-group">
                                <label for="name">Pseudonyme</label>
                                <input id="name" type="text" placeholder="Pseudonyme" name="pseudo">
                            </div>
                            <div class="pure-control-group">
                                <label for="name">Mot de passe</label>
                                <input id="name" type="password" placeholder="Mot de passe" name="pass">
                            </div>
                            <div class="pure-control-group">
                                <label for="name">Adresse mail</label>
                                <input id="name" type="text" placeholder="Email" name="mail">
                            </div>
                            <div class="pure-controls">
                                <button type="submit" class="pure-button pure-button-primary" name="register">S'inscrire !</button>
                            </div>
                        </form>
                    </div>
                    <?php } ?>
                </div>
            </div>
        </section>
     
        <?php include('includes/footer.php'); ?>
        <a href="#" id="toTop" class="fa fa-chevron-up"></a>
    </div>
    </body>
     
    </html>
    Et un screenshot de la structure de la table :
    Nom : 9beb13ffe1.png
Affichages : 93
Taille : 45,8 Ko

    Voilà. Merci beaucoup de votre aide.

  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
    Points : 44 155
    Points
    44 155
    Par défaut
    Il faut que tu fasses le degugage minimum :
    - ton code va t'il bien jusqu'à l'execution de la requête ? un simple echo suffit pour le savoir
    - que vaut $rows ?
    - y'a t'il des erreurs PDO ? http://php.net/manual/fr/pdo.error-handling.php

    Au passage quand même
    - retire tes htmlspecialchars(stripcslashes( qui ne servent à rien puisque tu fais des requêtes préparées.
    - tu as un bout de code qui ne sert à rien
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    $query3 = $sql->query("SELECT * FROM users");
                                    while($req2 = $query3->fetch()) {
                                        $id = $req2['id'];
                                        $id++;
                                    }
    - donne des noms cohérents à tes variables, parcer que $req2, $tquery, $query3 ... on s'y perd $req2 = $query3
    - enlève l'id de ta requête d'insertion et met NOW() à la place de la date en PHP.

  3. #3
    Nouveau Candidat au Club
    Homme Profil pro
    Webmaster
    Inscrit en
    Mai 2015
    Messages
    6
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 28
    Localisation : France, Seine et Marne (Île de France)

    Informations professionnelles :
    Activité : Webmaster

    Informations forums :
    Inscription : Mai 2015
    Messages : 6
    Points : 1
    Points
    1
    Par défaut Inutile de citer
    Merci de ta réponse rapide ^^.

    $rows vaut 0, et présentement, il n'y a aucune erreur pdo :/. De plus, le code est bel et bien executé jusqu'à la fin, juste l'insertion ne fonctionne pas :/.

    Merci pour les htmlspecialchars, et les stripcslashes .
    Le bout de code, une longue histoire, mais merci, je le retire :p.

    Pour now(), ça fonctionne comment s'il te plait ? J'ai pas trouvé de doc à ce sujet :s.

  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
    Points : 44 155
    Points
    44 155
    Par défaut
    Que le code soit executé jusqu'à la fin je n'en doute pas mais est-ce qu'il passe par l'insertion ?
    Il n'y a que 3 possibilités :
    - ton code exécute cette requête et il y a une insertion
    - ton code exécute cette requête et il y a une erreur SQL remontée par PDO (est-ce que tes erreurs PDO sont actives ?)
    - ton code contourne cette requpete

    Pour now() c'est très simple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $tquery = "INSERT INTO users (pseudo, pass, mail, rang, avatar, join) VALUES(:pseudo, :pass, :mail, :rang, :avatar, NOW())";

  5. #5
    Nouveau Candidat au Club
    Homme Profil pro
    Webmaster
    Inscrit en
    Mai 2015
    Messages
    6
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 28
    Localisation : France, Seine et Marne (Île de France)

    Informations professionnelles :
    Activité : Webmaster

    Informations forums :
    Inscription : Mai 2015
    Messages : 6
    Points : 1
    Points
    1
    Par défaut
    Voici ce que j'ai mis :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    $query2 = $sql->prepare("INSERT INTO users (pseudo, pass, mail, rang, avatar, join) VALUES (:pseudo, :pass, :mail, :rang, :avatar, NOW())");
    try {
        $query2->execute(array(
            ":pseudo" => $pseudo,
            ":pass" => $pass,
            ":mail" => $mail,
            ":rang" => "Membre",
            ":avatar" => "url.jpg"
        ));
    }
    catch (PDOException $e) {
        echo 'Error : ' . $e->getMessage();
        die();
    }
    Et quand je luis demande d'afficher $rows2 j'obtiens :
    0 ligne insérée.
    Enregistrement réussi ! Vous pouvez vous connecter en cliquant ici.
    EDIT :

    En revanche, quand je fais ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    $query2 = $sql->prepare("INSERT INTO users (pseudo, pass, mail, rang, avatar, join) VALUES (:pseudo, :pass, :mail, :rang, :avatar, NOW())");
       $query2->execute(array(
       ":pseudo" => $pseudo,
       ":pass" => $pass,
       ":mail" => $mail,
       ":rang" => "Membre",
       ":avatar" => "url.jpg"
    )) or die(print_r($sql->errorInfo()));
    J'obtiens :
    Array ( [0] => 00000 [1] => [2] => ) 1
    Et l'affichage de ma page se stoppe.

  6. #6
    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
    Points : 44 155
    Points
    44 155
    Par défaut
    Est-ce que tes erreurs PDO sont actives ?

  7. #7
    Nouveau Candidat au Club
    Homme Profil pro
    Webmaster
    Inscrit en
    Mai 2015
    Messages
    6
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 28
    Localisation : France, Seine et Marne (Île de France)

    Informations professionnelles :
    Activité : Webmaster

    Informations forums :
    Inscription : Mai 2015
    Messages : 6
    Points : 1
    Points
    1
    Par défaut
    Comment je vérifie ça ? ^^'.

    Si c'est au niveau de la connexion à la bdd, voici ce que je fais :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    <?php
    $utilisateur = "root";
    $motdepasse = "";
    $sql = new PDO('mysql:host=localhost;dbname=ygoshare', $utilisateur, $motdepasse);
    $sql->exec('SET NAMES utf8');
    ?>
    Je ne sais comment y activer les erreurs :/

  8. #8
    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
    Points : 44 155
    Points
    44 155
    Par défaut
    C'était le sujet du lien que je t'ai donné au début :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $sql->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);

  9. #9
    Nouveau Candidat au Club
    Homme Profil pro
    Webmaster
    Inscrit en
    Mai 2015
    Messages
    6
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 28
    Localisation : France, Seine et Marne (Île de France)

    Informations professionnelles :
    Activité : Webmaster

    Informations forums :
    Inscription : Mai 2015
    Messages : 6
    Points : 1
    Points
    1
    Par défaut
    Oh, c'est beaucoup mieux, merci beaucoup.

    J'obtiens désormais ce message :
    Fatal error: Uncaught exception 'PDOException' with message 'SQLSTATE[42000]: Syntax error or access violation: 1064 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 'join) VALUES ('Lord Korasoaa', '47bce5c74f589f4867dbd57e9ca9f808', 'a@a.a', 'Mem' at line 1' in G:\xampp\htdocs\YgoShare\login.php:98 Stack trace: #0 G:\xampp\htdocs\YgoShare\login.php(98): PDOStatement->execute(Array) #1 {main} thrown in G:\xampp\htdocs\YgoShare\login.php on line 98
    Visiblement, je vois que le nom de colonne join a pas l'air de lui plaire :/. C'est vrai que dans l'éditeur, il me colore join, je ne sais pas pourquoi (et je n'y prêtais pas d'importance.

    Merci de l'attention que tu portes à ce sujet, et la patience dont tu fais preuve ^^'.

  10. #10
    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
    Points : 44 155
    Points
    44 155
    Par défaut
    JOIN est un mot reservé, change le nom de ta colonne.

  11. #11
    Nouveau Candidat au Club
    Homme Profil pro
    Webmaster
    Inscrit en
    Mai 2015
    Messages
    6
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 28
    Localisation : France, Seine et Marne (Île de France)

    Informations professionnelles :
    Activité : Webmaster

    Informations forums :
    Inscription : Mai 2015
    Messages : 6
    Points : 1
    Points
    1
    Par défaut
    Okey merci beaucoup. Je sais maintenant que ce qui me prend la tête depuis hier c'est juste un nom de colonne foireux. J'ai un peu les boules quand meme

    M'enfin, merci beaucoup de l'aide que tu m'as apporté. Je t'en remercie.

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

Discussions similaires

  1. [AC-2003] Insertion de données manquante (fonction coalesce sous Access)
    Par JGLord dans le forum Requêtes et SQL.
    Réponses: 5
    Dernier message: 27/03/2013, 17h51
  2. [11g] Insertion de données manquantes
    Par JGLord dans le forum SQL
    Réponses: 5
    Dernier message: 12/03/2013, 12h23
  3. insertion d'enregistrements manquants
    Par verdifre dans le forum Requêtes
    Réponses: 8
    Dernier message: 24/08/2012, 13h26
  4. Insertion si valeur manquante
    Par poitierjohan dans le forum Langage
    Réponses: 6
    Dernier message: 04/07/2008, 11h49
  5. Objet manquant dans le menu insertion
    Par Speedy08 dans le forum Access
    Réponses: 3
    Dernier message: 17/03/2006, 20h19

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