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 :

pas d'insertion dans bdd [MySQL]


Sujet :

PHP & Base de données

  1. #1
    Membre régulier
    Femme Profil pro
    Inscrit en
    Juillet 2012
    Messages
    210
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Secteur : Service public

    Informations forums :
    Inscription : Juillet 2012
    Messages : 210
    Points : 92
    Points
    92
    Par défaut pas d'insertion dans bdd
    Bonsoir,
    Mon problème est très classique mais je n'arrive pas à le régler : j'ai un formulaire php qui insère des données dans une bdd via un formulaire.
    Tout se passait bien en local (plus maintenant !) mais après passage sur le serveur l'insertion en bdd ne se fait pas.
    Je n'arrive pas à avoir un message d'erreur pourtant ma connexion PDO est bien encadrée par try... catch ?
    J'ai fait de multiples echos, tout fonctionne jusqu'à la variable $auteur, ligne 60, mais il ne s'agit que d'affichage, rien n'est inséré dans la bdd.
    Je vous soumets ci-dessous le code du traitement du formulaire et vous remercie par avance si vous pouviez m'indiquer où se situe mon 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
    162
    163
    164
    165
    166
    167
    168
    169
    170
    171
    172
    173
    174
    175
    176
    177
    178
    179
    180
    181
    182
    183
    184
    185
    186
    187
    188
    189
    190
    191
    192
    193
    194
    195
    196
    197
    198
    199
    200
    201
    202
    203
    204
    205
    206
    207
    208
    209
    210
    211
    212
    213
    214
    215
    216
    217
    218
    219
    220
    221
    222
    223
    224
    225
    226
    227
    228
    229
    230
    231
    232
    233
    234
    235
    236
    237
    238
    239
    240
    241
    242
    243
    244
    245
    246
    247
    248
    249
    250
    251
    252
    253
    254
    255
    256
    257
    258
    259
    260
    261
    262
    263
    264
    265
    266
    267
    268
    269
    270
    271
    272
    273
    274
    275
    276
    277
    278
    279
     
    <?php
    session_start();
    include('include/connect.inc.php');
     
    //******************************************
    echo "<b>Vérification isset puis récupération et affichage des champs obligatoires :</b><br>";
     
    // on teste la déclaration de nos variables des champs obligatoires
    if (isset($_POST['identification']) && isset($_POST['langue']) && isset($_POST['ID_intervenant']) && isset($_POST['date']) ) 
    {
    echo "<br>Identification = ";
    echo $_POST['identification'];
     
    echo "<br>Langue = ";
    echo $_POST['langue'];
     
    echo "<br>Intervenant = ";
    echo $_POST['ID_intervenant'];
     
    echo "<br>Date = ";
    echo $_POST['date'];
    }
     
    //******************************************
    echo "<br><br><b>Affichage après simplification des noms de variables</b>";
    $idendification=$_POST['identification'];
    $langue=$_POST['langue'];
    $intervenant=$_POST['ID_intervenant'];
    $date=$_POST['date'];
     
    echo "<br>Identification =  $idendification";
    echo "<br>Langue =  $langue";
    echo "<br>Intervenant = $intervenant";
    echo "<br>Date = $date";
     
    //****************************************** auteur
    echo "<br><br><b>sans vérification isset, juste récupération et affichage des champs NON obligatoires de la table TEXTE :</b><br>";
     
    if (isset($_POST['langue']) ) {
            if ($_POST['langue'] == 1)
            {
                $auteur=$_POST['auteur_grec'];
                echo "<br><br>voilà un auteur Grec : $auteur";
            }
            elseif ($_POST['langue'] == 2 )
            {
                $auteur=$_POST['auteur_latin'];
                echo "<br><br>voilà un auteur Latin : $auteur";
            }
            elseif ($_POST['langue'] == 6 )
            {
                $auteur=$_POST['auteur_hebreu'];
                echo "<br><br>voilà un auteur Hébreu : $auteur";
            }
    }
    else
    {
        echo "il y a une erreur auteur";
    }
     
    //préparation inserts dans la table principale TEXTE
    $requete = $base->prepare('INSERT INTO TEXTE(identification, extrait, mot_cle, interet, epoque, edition, traduction, auteur_traduction, bibliographie, interrogation, ID_langue, ID_auteur, prec_texte, prec_langue_autre, prec_auteur_grec_autre, prec_insc_grec, prec_topo_grec, prec_auteur_latin_autre, prec_insc_latin, prec_topo_latin, prec_auteur_hebreu_autre, prec_insc_hebreu, prec_topo_hebreu, prec_interv_autre, prec_metal_autre, prec_theme_autre) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?) ');	
     
    $requete->execute(array($identification, $_POST['extrait'], $_POST['mot_cle'], $_POST['interet'], $_POST['epoque'], $_POST['edition'], $_POST['traduction'], $_POST['auteur_traduction'], $_POST['bibliographie'], $_POST['interrogations'], $langue, $auteur, $_POST['precision_texte'], $_POST['texte_langue_autre'], $_POST['text_grec_autre'], $_POST['text_grec_inscription'], $_POST['text_grec_toponyme'], $_POST['text_latin_autre'],$_POST['text_latin_inscription'], $_POST['text_latin_toponyme'], $_POST['text_hebreu_autre'], $_POST['text_hebreu_inscription'], $_POST['text_hebreu_toponyme'], $_POST['prec_intervenant_autre'], $_POST['prec_metal_autre'], $_POST['prec_theme_autre']) );
     
    //récupération ID_texte
    $resultat = $base->query("SELECT ID_texte FROM TEXTE ORDER BY ID_texte DESC LIMIT 1") or die($mysqli->error.__LINE__);
        $arr = array(); 
        while($row = $resultat->fetch()) { $arr[] = $row; }
        $recup = ($arr);
     
    foreach($recup as $evenement){	
    $ID_texte = "$evenement[ID_texte]";
    }
     
    //préparation inserts dans la table HISTORIQUE   
    $requete2 = $base->prepare('INSERT INTO HISTORIQUE(date_creation, ID_intervenant, ID_texte) VALUES (?, ?, ?) ');
    $requete2->execute(array($date, $intervenant, $ID_texte ));
     
    //préparation inserts dans la table AS_TEXTE_METAL
    // Le tableau $_POST['metal'] contient les valeurs des checkbox cochées
    $requete3 = $base->prepare('INSERT INTO AS_TEXTE_METAL (ID_texte, ID_metal) VALUES (?, ?) ');
    if(empty($_POST['metal'])) {
       echo "Aucune checkbox métal n'a été cochée";
    }
    else
    {  
      foreach($_POST['metal'] as $valeur1)
      {  	
      $requete3->execute(array($ID_texte, $valeur1) ); 
      }
    }
     
    //préparation inserts dans la table AS_TEXTE_THEME
    // Le tableau $_POST['theme'] contient les valeurs des checkbox cochées
    $requete4 = $base->prepare('INSERT INTO AS_TEXTE_THEME (ID_texte, ID_theme) VALUES (?, ?) ');
    if(empty($_POST['theme'])) {
       echo "Aucune checkbox thème n'a été cochée";
    }
    else
    {  
      foreach($_POST['theme'] as $valeur2)
      {  	
      $requete4->execute(array($ID_texte, $valeur2) ); 
      }
    }
    ?>
     
    <!DOCTYPE html>
    <html>
        <head>
            <title>Traitement formulaire</title>
     
            <meta name="viewport" content="width=device-width, initial-scale=1">
            <meta charset="utf-8" />       
    	</head>
     
    <body>
     
    <div id="fil_site" class="acces_fond" style="border-bottom:none;">
        <span><a href="index.php">Accueil METALLA &#x25b6;</a></span>   
    </div>
     
    <p>
    Bonjour, l'enregistrement a bien été effectué, vous pouvez visualiser ci-dessous le résultat : 
    </p>
     
    <?php
     
    echo "<br>derniers inserts  après insertion bbb : ";
    $theme=$_POST['theme'];
    echo "<br>Thème =  $theme";
     
    echo "<br>derniers inserts  après insertion bbb : ";
    $theme=$_POST['metal'];
    echo "<br>Métal =  $metal";
     
    $resultat = $base->query("SELECT * FROM TEXTE ORDER BY ID_texte DESC LIMIT 1") or die($mysqli->error.__LINE__);
     
        $arr = array(); 
        while($row = $resultat->fetch()) { $arr[] = $row; }
        $recup = ($arr);
    ?>
     
    <table><br>
     
    <?php
     
    foreach($recup as $evenement){
     
    	echo "<tr>";
    	echo "<td>Identification : ";
    	echo "<td><font color=#993333>$evenement[identification]</font></td>";
    	echo "</tr>";
     
    	echo "<tr>";
    	echo "<td>Extrait : ";
    	echo "<td><font color=#993333>$evenement[extrait]</font></td>";
    	echo "</tr>";
     
    	echo "<tr>";
    	echo "<td>Mots clés : ";
    	echo "<td><font color=#993333>$evenement[mot_cle]</font></td>";
    	echo "</tr>";
     
    	echo "<tr>";
    	echo "<td>Intérêt : ";
    	echo "<td><font color=#993333>$evenement[interet]</font></td>";
    	echo "</tr>";
     
    	echo "<tr>";
    	echo "<td>Epoque : ";
    	echo "<td><font color=#993333>$evenement[epoque]</font></td>";
    	echo "</tr>";
     
    	echo "<tr>";
    	echo "<td>Edition : ";
    	echo "<td><font color=#993333>$evenement[edition]</font></td>";
    	echo "</tr>";	
     
    	echo "<tr>";
    	echo "<td>Traduction : ";
    	echo "<td><font color=#993333>$evenement[traduction]</font></td>";
    	echo "</tr>";
     
    	echo "<tr>";
    	echo "<td>Auteur traduction : ";
    	echo "<td><font color=#993333>$evenement[auteur_traduction]</font></td>";
    	echo "</tr>";
     
    	echo "<tr>";
    	echo "<td>Bibliographie : ";
    	echo "<td><font color=#993333>$evenement[bibliographie]</font></td>";
    	echo "</tr>";
     
    	echo "<tr>";
    	echo "<td>Interrogations : ";
    	echo "<td><font color=#993333>$evenement[interrogation]</font></td>";
    	echo "</tr>";
     
    	echo "<tr>";
    	echo "<td>Langue : ";
    	echo "<td><font color=#993333>$evenement[langue]</font></td>";
    	echo "</tr>";
     
    	echo "<tr>";
    	echo "<td>Auteur : ";
    	echo "<td><font color=#993333>$evenement[auteur]</font></td>";
    	echo "</tr>";
     
    	echo "<tr>";
    	echo "<td>Précision sur le texte : ";
    	echo "<td><font color=#993333>$evenement[prec_texte]</font></td>";
    	echo "</tr>";
     
    	echo "<tr>";
    	echo "<td>Précision langue autre : ";
    	echo "<td><font color=#993333>$evenement[prec_langue_autre]</font></td>";
    	echo "</tr>";
     
    	echo "<tr>";
    	echo "<td>Précision auteur Grec autre : ";
    	echo "<td><font color=#993333>$evenement[prec_auteur_grec_autre]</font></td>";
    	echo "</tr>";
     
    	echo "<tr>";
    	echo "<td>Précision inscription Grec : ";
    	echo "<td><font color=#993333>$evenement[prec_insc_grec]</font></td>";
    	echo "</tr>";
     
    	echo "<tr>";
    	echo "<td>Précision topographie Grec : ";
    	echo "<td><font color=#993333>$evenement[prec_topo_grec]</font></td>";
    	echo "</tr>";
     
    	echo "<tr>";
    	echo "<td>Précision auteur Latin autre : ";
    	echo "<td><font color=#993333>$evenement[prec_auteur_latin_autre]</font></td>";
    	echo "</tr>";	
     
    	echo "<tr>";
    	echo "<td>Précision inscription Latin : ";
    	echo "<td><font color=#993333>$evenement[prec_insc_latin]</font></td>";
    	echo "</tr>";
     
    	echo "<tr>";
    	echo "<td>Précision topographie Latin : ";
    	echo "<td><font color=#993333>$evenement[prec_topo_latin]</font></td>";
    	echo "</tr>";
     
    	echo "<tr>";
    	echo "<td>Précision auteur Hébreu autre : ";
    	echo "<td><font color=#993333>$evenement[prec_auteur_hebreu_autre]</font></td>";
    	echo "</tr>";	
     
    	echo "<tr>";
    	echo "<td>Précision inscription Hébreu : ";
    	echo "<td><font color=#993333>$evenement[prec_insc_hebreu]</font></td>";
    	echo "</tr>";
     
    	echo "<tr>";
    	echo "<td>Précision topographie Hébreu : ";
    	echo "<td><font color=#993333>$evenement[prec_topo_hebreu]</font></td>";
    	echo "</tr>";
     
    	echo "<tr>";
    	echo "<td>Précision intervenant autre : ";
    	echo "<td><font color=#993333>$evenement[prec_interv_autre]</font></td>";
    	echo "</tr>";
     
    }
    ?>
     
    </table>
     
    </body>
     
    </html>

  2. #2
    Membre expert
    Avatar de Dendrite
    Femme Profil pro
    Développeuse informatique
    Inscrit en
    Juin 2008
    Messages
    2 129
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 58
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeuse informatique
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Juin 2008
    Messages : 2 129
    Points : 3 627
    Points
    3 627
    Billets dans le blog
    8
    Par défaut
    Bonjour Evelyne,

    Il faut suivre ce tuto pour le chapitre de la connexion et pour le chapitre de l'insertion. Donc chapitres 3 et 7 ! Tout est expliqué dedans.

    PDO une soupe et au lit !
    PDO, une soupe et au lit !
    Partir de la fin est un bon moyen de retrouver son chemin. Bibi - 2020

  3. #3
    Invité
    Invité(e)
    Par défaut
    Bonjour,

    ...ma connexion PDO est bien encadrée par try... catch...
    Oui, c'est bien.

    Mais il faut en faire autant AUTOUR DE CHAQUE requête SQL (prepare/execute) si tu veux pouvoir afficher les erreurs/exceptions !


    LIS et suis bien le tuto fourni par Dendrite

  4. #4
    Membre régulier
    Femme Profil pro
    Inscrit en
    Juillet 2012
    Messages
    210
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Secteur : Service public

    Informations forums :
    Inscription : Juillet 2012
    Messages : 210
    Points : 92
    Points
    92
    Par défaut
    Bonsoir Dendrite et jreaux62,
    Merci beaucoup pour vos réponses, je me plonge dans le tuto conseillé par Dendrite et vous tiens informés.
    A +
    Evelyne31

  5. #5
    Membre régulier
    Femme Profil pro
    Inscrit en
    Juillet 2012
    Messages
    210
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Secteur : Service public

    Informations forums :
    Inscription : Juillet 2012
    Messages : 210
    Points : 92
    Points
    92
    Par défaut
    Bonsoir,
    Je reviens avec malheureusement un message d'erreur dès le début de mes tentatives !
    Je suis le tuto transmis par Dendrite, j'en suis au début, au chapitre 3.
    Cela fait un moment que je suis là-dessus sans succès et vous transmets mon code de connexion initial (fichier connect.inc.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
     
    <?php
    try
    {
    	$base = new PDO('mysql:host=127.0.0.1;dbname=xxxxxxx', 'xxxxxxx', 'xxxxxxxxxx', array(PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION));
     
    }
    catch(Exception $e)
    {
            die('Erreur : '.$e->getMessage());
    }
    $base->query("SET NAMES UTF8");
     
    ?>
    Après le fichier traitement.php, s'affichent ici, sans insertion dans la bdd, par des echos, les données postées jusqu'au nom de l'auteur seulement. Après = page blanche !

    et voici le code que j'ai rectifié en suivant les indications du tuto (fichier connect.inc.php) en remplant juste les $pdo par $base :
    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
     
    <?php
    // @author : rawsrc - 2018 - Pour DVP
    // on vérifie si la fonction de connexion a déjà été définie afin d'éviter de la redéfinir
    if ( ! function_exists('db_connexion')) {
       function db_connexion() {
          // une fois ouverte, on renvoie toujours la même connexion
          static $base;
          // on vérifie si la connexion n'a pas déjà été initialisée
          if ( ! ($base instanceof PDO)) {
             // tentative d'ouverture de la connexion MySQL
             try {
                $base = new PDO('mysql:host=localhost;port=XXXXXX;dbname=XXXXXX;charset=utf8','XXXXXX', 'XXXXXX', [
                PDO::ATTR_ERRMODE            => PDO::ERRMODE_EXCEPTION,
                PDO::ATTR_EMULATE_PREPARES   => false
                ]);
             } 
             catch (PDOException $e) {
                throw new InvalidArgumentException('Erreur connexion à la base de données : '.$e->getMessage());
                exit;
             }
          }
          // renvoi de la ressource : connexion à la base de données
          return $base;
       }
    }
    return db_connexion();
    ?>
    Merci par avance pour vos conseils.
    Evelyne31

  6. #6
    Membre expert
    Avatar de Dendrite
    Femme Profil pro
    Développeuse informatique
    Inscrit en
    Juin 2008
    Messages
    2 129
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 58
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeuse informatique
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Juin 2008
    Messages : 2 129
    Points : 3 627
    Points
    3 627
    Billets dans le blog
    8
    Par défaut
    eh bien ? Passe au 7 pour voir si cette connexion fonctionne ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $base = include 'connect.inc.php';
    PDO, une soupe et au lit !
    Partir de la fin est un bon moyen de retrouver son chemin. Bibi - 2020

  7. #7
    Membre régulier
    Femme Profil pro
    Inscrit en
    Juillet 2012
    Messages
    210
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Secteur : Service public

    Informations forums :
    Inscription : Juillet 2012
    Messages : 210
    Points : 92
    Points
    92
    Par défaut
    Très déçue, j'abandonne pour ce soir
    Ce que j'ai tenté :

    1 - j'ai remplacé la dernière ligne de mon fichier de connexion par
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $base = db_connexion();
    et j'obtiens l'erreur suivante :
    Fatal error: Uncaught Error: Call to undefined function db_connexion() in /Applications/MAMP/htdocs/metalla/include/connect.inc.php:11 Stack trace: #0 /Applications/MAMP/htdocs/metalla/include/checklogin.php(3): require_once() #1 {main} thrown in /Applications/MAMP/htdocs/metalla/include/connect.inc.php on line 11La ligne 11 c'est la ligne que j'ai rectifiée : par $base = db_connexion();

    2 - J'ai crée un fichier "contact.php" à la racine du site et les tables correspondantes dans la bdd.
    J'ai tenté une insertion. Voici le message d'erreur obtenu quand je tape "http://localhost:8888/contact.php" dans mon navigateur :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Parse error: syntax error, unexpected ';', expecting ',' or ')' in /Applications/MAMP/htdocs/metalla/contact.php on line 4
    .
    Je sais que c'est une erreur de débutante mais là je cale.

    Ci-dessous le code complet du fichier contact.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
    26
    27
    28
     
    <?php
    //on supprime les guillemets d’une chaîne SQL, PDO s’en occupera
    //on remplace l’id auto-increment par NULL, la table s’en chargera
    $sql='INSERT INTO contact (id, nom, prenom, mail) VALUES (NULL, ?, ?, ?)';
    //on initialise notre tableau PHP
    $data=array();
    $base = include 'connect.inc.php';
    try { 
       //la ligne qui lance la requête préparée
       $stmt = $base->prepare($sql);
       //on affecte les marqueurs précis sur les filtres
       //en vrai, vous aurez plutôt des variables de type POST envoyées par un formulaire
       $nom='GAILLARD';
       $prenom='Geneviève';
       $mail='genevieve.gaillard@gmail.com';
       //Attention, bien mettre dans l'ordre de la requête ! Nom puis prenom puis mail
       $stmt->execute(array($nom,$prenom,$mail)) ;
       // on peut récupérer le nombre de lignes affectées 
       $nb_insert = $stmt->rowCount();
       echo $nb_insert.' insertion effectuée<br/>';
       unset($base);
    } 
    catch (Exception $e) {
       //s'il y a un problème PHP ou SQL, tout s'affichera ici
       print "Erreur ! " . $e->getMessage() . "<br/>";
    }
    ?>
    Merci par avance si vous pouviez m'orienter un peu vers la source de mes erreurs
    Très bonne soirée,
    Evelyne31

  8. #8
    Membre extrêmement actif
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Avril 2018
    Messages
    537
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Administrateur de base de données

    Informations forums :
    Inscription : Avril 2018
    Messages : 537
    Points : 634
    Points
    634
    Par défaut
    Bonsoir

    $idendification ca s'écrit identification


    on voit pas le code du 1

    ca sert à rien si tu l'utilise pas

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $stmt->execute(array($nom ,$prenom, $mail));
    je n'utilise pas pdo mais ça s'ecrit comme ça.

  9. #9
    Membre expert
    Avatar de Dendrite
    Femme Profil pro
    Développeuse informatique
    Inscrit en
    Juin 2008
    Messages
    2 129
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 58
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeuse informatique
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Juin 2008
    Messages : 2 129
    Points : 3 627
    Points
    3 627
    Billets dans le blog
    8
    Par défaut
    Evelyne,

    Alors
    1) reprends le 3. J'ai ajouté un petit paragraphe "comment vérifier que votre connexion fonctionne ?".
    Merci du conseil Jreaux.
    OK le fichier de connexion de Rawsrc est un peu complexe pour un débutant. Mais il présente 2 gros avantages
    - très simple à modifier si l'on ne touche QUE les paramètres de connexion.
    - encore plus simple à convoquer en toute sécurité : une seule et unique ligne ! On ne peut pas faire mieux.

    Donc reprends le 3, et dis moi si tu as un message d'erreur ou non à la connexion.
    Si non, si tu ne vois rien, c'est que tout va bien.
    Je te propose de continuer ainsi.

    2) Reprends le 5 (select sans filtre) et montre nous comment tu le changes a minima à partir de ta requête SQL qui fonctionne dans ta base.
    Puis reprends le 6 (select avec filtre) et ajoute tes variables PHP de type POST.

    Bonne chance, PDO, c'est juste un coup à prendre.
    PDO, une soupe et au lit !
    Partir de la fin est un bon moyen de retrouver son chemin. Bibi - 2020

  10. #10
    Membre régulier
    Femme Profil pro
    Inscrit en
    Juillet 2012
    Messages
    210
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Secteur : Service public

    Informations forums :
    Inscription : Juillet 2012
    Messages : 210
    Points : 92
    Points
    92
    Par défaut
    Bonjour bonjourajax et Dendrite,
    J'ai repris depuis un moment déjà ! J'ai repris le 3 et malheureusement = page blanche sans message d'erreur.
    Pour être sûre, est-ce que la ligne des paramètres de connexion ci-dessous vous semble correcte ? J'ai enlevé le port car je travaille sur un serveur et je n'ai pas cette info.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    $pdo = new PDO('mysql:host=XXXXX;dbname=XXXXX;charset=utf8','XXXXX', 'XXXXX', [
    Je ne me décourage pas.
    Merci et bonne journée,
    Evelyne31

  11. #11
    Invité
    Invité(e)
    Par défaut
    Évelyne,

    OUBLIE ce que j'ai dit !!
    (J'ai inutilement créé une confusion)

    REMETS :
    • Fais EXACTEMENT ce qui est indiqué dans le tuto.
    • Et ECOUTE en priorité Dendrite

  12. #12
    Membre expert
    Avatar de Dendrite
    Femme Profil pro
    Développeuse informatique
    Inscrit en
    Juin 2008
    Messages
    2 129
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 58
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeuse informatique
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Juin 2008
    Messages : 2 129
    Points : 3 627
    Points
    3 627
    Billets dans le blog
    8
    Par défaut
    J'ai repris le 3 et malheureusement = page blanche sans message d'erreur.
    Non, ça c'est tout bon. Ca veut dire que tu peux continuer, ta connexion fonctionne.
    On passe au 5 ?
    Et tu poses ici ton script modifié pour un select sans where... et tu nous dis si tout fonctionne.

    Par rapport au code du tuto, tu ne modifies que le SQL, et pose cette ligne pour la connexion, si j'ai bien suivi...
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $base = include 'connect.inc.php';
    PDO, une soupe et au lit !
    Partir de la fin est un bon moyen de retrouver son chemin. Bibi - 2020

  13. #13
    Membre régulier
    Femme Profil pro
    Inscrit en
    Juillet 2012
    Messages
    210
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Secteur : Service public

    Informations forums :
    Inscription : Juillet 2012
    Messages : 210
    Points : 92
    Points
    92
    Par défaut
    Merci Dendrite,
    Toujours une page blanche sans rien.
    Comme je ne peux pas me connecter à mon Intranet, j'ai mis un lien sur ma page d'accueil vers le fichier contact.php et quand je clique : rien.
    J'ai bien créé la table "contact" dans ma bdd, j'ai testé les requêtes 5 et 6 dans phpmyadmin, c'est ok.

    Ci-dessous, je poste le code des 2 fichiers, j'ai sûrement fait une erreur stupide et vous remercie de bien vouloir regarder.
    Evelyne31

    1 - contact.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
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
     
    <?php
    //pas de filtre
    $base='SELECT *
    FROM contact
    ORDER BY nom, prenom;';
    //on initialise notre tableau PHP
    $data=array();
    $base = include 'db_mysql.php'; 
    try{
       //la ligne qui lance la requête préparée
       $stmt = $db->prepare($sql);
       //pas de filtres donc pas de paramètres
       $stmt->execute();
       //tant qu'il y a un enregistrement, range le dans un tableau associatif PHP (ici $row)
       while($row= $stmt->fetch(PDO::FETCH_ASSOC)){
          //le tableau $data intègre $row a chaque tour
          $data[]=$row;
       }
       unset($db);
       //$data est complet
       if(sizeof($data)>0){
          echo '<pre>';
          print_r($data);
          echo '</pre>';
       }
       //ceci n'est pas une exception 
       //il n'y a peut-etre pas encore de donnees dans la table !
       else{
          echo 'Aucun resultat pour cette requete';
       }
    } 
    catch (Exception $e) {
       //s'il y a un probleme PHP ou SQL, tout s'affichera ici
       print "Erreur ! " . $e->getMessage() . "<br/>";
    }
    ?>
    db_mysql.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
    26
    27
    28
     
    <?php
    // @author : rawsrc - 2018 - Pour DVP
    // on vérifie si la fonction de connexion a déjà été définie afin d'éviter de la redéfinir
    if ( ! function_exists('db_connexion')) {
       function db_connexion() {
          // une fois ouverte, on renvoie toujours la même connexion
          static $base;
          // on vérifie si la connexion n'a pas déjà été initialisée
          if ( ! ($base instanceof PDO)) {
             // tentative d'ouverture de la connexion MySQL
             try {
                $base = new PDO('mysql:host=XXXXX;dbname=XXXXX;charset=utf8','XXXXX', 'XXXXX', [
                PDO::ATTR_ERRMODE            => PDO::ERRMODE_EXCEPTION,
                PDO::ATTR_EMULATE_PREPARES   => false
                ]);
             } 
             catch (PDOException $e) {
                throw new InvalidArgumentException('Erreur connexion à la base de données : '.$e->getMessage());
                exit;
             }
          }
          // renvoi de la ressource : connexion à la base de données
          return $base;
       }
    }
    return db_connexion();
    ?>

  14. #14
    Invité
    Invité(e)
    Par défaut
    Évelyne,

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    $base='SELECT *..........;'; // ?????
    ...
    $base = include 'db_mysql.php'; 
    ...
       //la ligne qui lance la requête préparée
       $stmt = $db->prepare($sql);
    Tu ne peux pas avoir $base et $db !...


    1- Fais le tuto SANS RIEN changer !!

    Le tuto fonctionne tel quel : Ne change RIEN !


    2- et sans vouloir te vexer.... Ouvre les yeux et active le mode "cerveau".
    Il ne s'agit pas de copier "bêtement", mais de comprendre le code...


    3- Quand tu auras compris le principe, tu pourras :

    • remplacer le nom de la variable de connexion... Partout !
    • adapter ce principe à ton propre code, en toute connaissance de cause
    Dernière modification par Invité ; 01/06/2018 à 12h39.

  15. #15
    Membre régulier
    Femme Profil pro
    Inscrit en
    Juillet 2012
    Messages
    210
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Secteur : Service public

    Informations forums :
    Inscription : Juillet 2012
    Messages : 210
    Points : 92
    Points
    92
    Par défaut
    Merci jreaux62, c'est re-parti selon tes conseils.

    Partie 5 : OK, je récupère tous les 10 enregistrements (0 à 9).

    Partie 6 : OK, je récupère 2 enregistrements CHAZAL Chantal et Claire.

    Je poursuis le reste du tuto de suite.

    Evelyne31

  16. #16
    Invité
    Invité(e)
    Par défaut
    Super !

    Dès que tu te sens prête :
    • Corrige ton code perso (celui de ton 1er message)
    • Montre-nous la correction (ajoute entre autres des try / catch autour des requêtes)
    • Et montre éventuellement le message d'erreur

    Ensuite, on en reparlera :
    • il y aura d'autres erreurs à corriger,
    • et des optimisations le code à faire.

  17. #17
    Membre régulier
    Femme Profil pro
    Inscrit en
    Juillet 2012
    Messages
    210
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Secteur : Service public

    Informations forums :
    Inscription : Juillet 2012
    Messages : 210
    Points : 92
    Points
    92
    Par défaut
    OK merci, ça marche, je prends le temps de faire ça bien durant le week-end.
    Très bon week-end,
    Evelyne31

  18. #18
    Membre extrêmement actif
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Avril 2018
    Messages
    537
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Administrateur de base de données

    Informations forums :
    Inscription : Avril 2018
    Messages : 537
    Points : 634
    Points
    634
    Par défaut
    Effectivement tu as mélangé la requête sql avec la connexion à la base de données.
    non en fait tu as tout mélangé mieux vaut recommencer de 0 avec le tuto

  19. #19
    Membre régulier
    Femme Profil pro
    Inscrit en
    Juillet 2012
    Messages
    210
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Secteur : Service public

    Informations forums :
    Inscription : Juillet 2012
    Messages : 210
    Points : 92
    Points
    92
    Par défaut
    Bonsoir,
    Je reviens poster le résultat de mes essais pour adapter mon code avec le tuto "PDO une soupe et au lit". Oui, je sais bonjourajax que je mélange un peu tout, désolée mais j'essaie de m'améliorer !
    Pour ce qui est de la connexion, je suis contente, tout est OK avec le nouveau code, je le poste ci-dessous.

    Par contre, pour mon formulaire, la connexion à la bdd ne se fait plus.
    J'ai testé pour le 1er menu déroulant mais il reste vide et je n'ai pas de message d'erreur.
    J'ai fait 2 essais : 1° en entourant ma 1ère requête du bloc try / catch et 2° en remplaçant mon code initial par celui de la partie 5 du tuto "Requête SELECT sans filtre".

    La semaine prochaine je suis absente, mais dès mon retour je reprendrai car cela m'intéresse beaucoup. Je vous remercie très sincèrement pour vos conseils,
    Evelyne31

    Code de connexion à la bdd :
    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
     
    <?php
    // @author : rawsrc - 2018 - Pour DVP
    // on vérifie si la fonction de connexion a déjà été définie afin d'éviter de la redéfinir
    if ( ! function_exists('db_connexion')) {
       function db_connexion() {
          // une fois ouverte, on renvoie toujours la même connexion
          static $base;
          // on vérifie si la connexion n'a pas déjà été initialisée
          if ( ! ($base instanceof PDO)) {
             // tentative d'ouverture de la connexion MySQL
             try {
                $base = new PDO('mysql:host=localhost;port=XXXXX;dbname=XXXXX;charset=utf8','root', 'root', [            
                PDO::ATTR_ERRMODE            => PDO::ERRMODE_EXCEPTION,
                PDO::ATTR_EMULATE_PREPARES   => false
                ]);
             } 
             catch (PDOException $e) {
                throw new InvalidArgumentException('Erreur connexion à la base de données : '.$e->getMessage());
                exit;
             }
          }
          // renvoi de la ressource : connexion à la base de données
          return $base;
       }
    }
    return db_connexion();
    ?>
    et dans le fichier de vérification du login "checklogin.php, j'ai inséré en début la ligne conseillée par Dendrite :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $base = include 'connect.inc.php';
    Code du 1er menu déroulant du formulaire, en entourant ma requête par le bloc try / catch :
    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
     
    <select id="langue-select" class="form-control" name="langue" required autofocus>
    <option value='' selected >Choisir une langue</option>
     
    	<?php
    	try{ 
       //ici vous écrivez tout votre script
       //jusqu’à la fin, s’il y a une exception, elle sera interceptée par le catch
     
    	$rech_langue = $base->query('SELECT * FROM LANGUE ORDER BY ID_langue');
    	foreach ($rech_langue as $langue)
    	{		
    	?>
     
    <option value="<?php echo $langue['ID_langue']?>"><?php echo $langue['nom_langue'] ?>
    </option>  
    	<?php
    	}
     
    	} 
    	catch(Exception $e){
    	   //s'il y a un probleme PHP ou SQL, que ce soit un warning ou une erreur fatale, tout s'affichera ici
    	   print "Erreur ! " . $e->getMessage() . "<br/>";
    	}
     
    	?>
    </select>
    Code du menu déroulant en remplaçant mon code par celui du tuto "SELECT sans filtre" :
    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
     
    <select id="langue-select" class="form-control" name="langue" required autofocus>
    <option value='' selected >Choisir une langue</option>
    <?php
    //pas de filtre
    $sql='SELECT *
    FROM LANGUE
    ORDER BY ID_langue;';
    //on initialise notre tableau PHP
    $data=array();
    $base = include 'include/connect.inc.php';
    try{
       //la ligne qui lance la requête préparée
       $stmt = $base->prepare($sql);
       //pas de filtres donc pas de paramètres
       $stmt->execute();
       //tant qu'il y a un enregistrement, range le dans un tableau associatif PHP (ici $row)
       while($row= $stmt->fetch(PDO::FETCH_ASSOC)){
          //le tableau $data intègre $row a chaque tour
          $data[]=$row;
       }
       unset($base);
       //$data est complet
       if(sizeof($data)>0){
          echo '<pre>';
          print_r($data);
          echo '</pre>';
       }
       //ceci n'est pas une exception 
       //il n'y a peut-etre pas encore de donnees dans la table !
       else{
          echo 'Aucun resultat pour cette requete';
       }
    } 
    catch (Exception $e) {
       //s'il y a un probleme PHP ou SQL, tout s'affichera ici
       print "Erreur ! " . $e->getMessage() . "<br/>";
    }
    ?>
    <option value="<?php echo $data['ID_langue']?>"><?php echo $data['nom_langue'] ?>
    </option>  
    </select>

  20. #20
    Membre extrêmement actif
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Avril 2018
    Messages
    537
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Administrateur de base de données

    Informations forums :
    Inscription : Avril 2018
    Messages : 537
    Points : 634
    Points
    634
    Par défaut
    c'est quoi l'erreur qui est envoyée pour que la connexion ne se fasse pas?
    il manque des points virgules partout et le dernier bloc de code est illogique (sinon la partie copier coller du tuto est correcte )

+ Répondre à la discussion
Cette discussion est résolue.
Page 1 sur 2 12 DernièreDernière

Discussions similaires

  1. Formulaire validé, mais pas d'insertion dans la BDD
    Par Jeanjan dans le forum Langage
    Réponses: 10
    Dernier message: 08/06/2014, 16h55
  2. [AC-2010] Pas d'insertion dans table après requête INSERT
    Par scrouet dans le forum VBA Access
    Réponses: 3
    Dernier message: 04/03/2013, 12h39
  3. Réponses: 10
    Dernier message: 07/09/2008, 13h38
  4. [MySQL] pas d'erreur mais l'insertion dans la base ne marche pas bien
    Par info_sara dans le forum PHP & Base de données
    Réponses: 1
    Dernier message: 21/05/2008, 14h55
  5. Réponses: 15
    Dernier message: 22/07/2005, 09h49

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