Partage
  • Partager sur Facebook
  • Partager sur Twitter

[ERREUR] uncaught error

Sujet résolu
    18 janvier 2023 à 18:35:16

    j'ai quelques soucis en php en faite j'essaie d'envoyer requete sql pour ajouter des utilisateur a ma base de donnees et m'affiche toujours le message suivant:

    Fatal error: Uncaught Error: Call to a member function prepare() on string in C:\wamp\www\DEVOI GROUPE SEUJIP\formulaire.php on line 21

    voici le code html:

    <!DOCTYPE html>
    <html>
    <head>
        <title>dred</title>
    </head>
    <body>
    
    <form method="post">
        <input type="email" name="email" placeholder="entrer votre email" id="email" required>
        <input type="text" name="password" placeholder="entrer votre mot de passe" id="password" required>
        <input type="text" name="cpassword" placeholder="reentrer votre mot de passe" id="cpassword" required>
        <input type="submit" name="formsend" id="formsend">
    </form>
    </body>
    </html>



    et voici le code php

    // defintion des constantes 
    define('host','localhost'); //seveur local
    define('password',''); // pas de mot de passe
    define('user','root'); // nom d'utilisateur 
    define('db_name','siteweb'); // nom de la base de donne
    
    // connection a la base de données
    
    $db="mysql:dbname=".db_name.";host=".host; 
    try{
    $connexion=new PDO($db,user,password);
    echo("connect");
    }
    catch(PDOException $e){
    echo("Échec de la connexion : %s\n", $e->getMessage());
    exit();
    }
    // code pour inserer un utilisateur 
    
    if (isset($_POST['formsend'])) {
    	if (!empty($_POST['email']) && !empty($_POST['password']) &&!empty($_POST['cpassword']) ) {
    		if ($_POST['password']== $_POST['cpassword']) {
    			$sql= 'INSERT INTO utilisateur (email,password) VALUES (:email,:password)';
    	$q = $db -> prepare($sql);
    	$q->bindValue(':email', $_POST['email']);
    	$q->bindValue(':password', $_POST['password']);
    	$q-> execute() ;
    
    		}
    	
    	}
    }


    -
    Edité par EmmanuelSeujip 18 janvier 2023 à 20:31:25

    • Partager sur Facebook
    • Partager sur Twitter
      18 janvier 2023 à 19:29:21

      Bonjour,

      où est défini $db ?

      Le message qui suit est une réponse automatique activée par un membre de l'équipe. Les réponses automatiques leur permettent d'éviter d'avoir à répéter de nombreuses fois la même chose, ce qui leur fait gagner du temps et leur permet de s'occuper des sujets qui méritent plus d'attention.
      Nous sommes néanmoins ouverts et si vous avez une question ou une remarque, n'hésitez pas à contacter la personne en question par Message Privé.

      Pour plus d'informations, nous vous invitons à lire les règles générales du forum

      Merci de colorer votre code à l'aide du bouton Code

      Les forums d'Openclassrooms disposent d'une fonctionnalité permettant de colorer et mettre en forme les codes source afin de les rendre plus lisibles et faciles à manipuler par les intervenants. Pour cela, il faut utiliser le bouton Code de l'éditeur, choisir un des langages proposés et coller votre code dans la zone prévue.

      Merci de modifier votre message d'origine en fonction.

      Mauvais titre

      Le titre est un élément important qui ne doit pas être négligé. N'oubliez pas cette règle simple : le titre idéal résume la question que vous allez poser en une petite phrase. Il doit permettre aux visiteurs de se repérer facilement dans le forum visité et d'identifier le sujet à sa seule lecture.

      Vous pouvez utiliser divers préfixes comme [Erreur], [MySQL], [Compatibilité], etc... Aussi, pensez à consulter les règles propres à chaque forum (visibles dans les topics épinglés en haut des sections).

      De plus, choisir un bon titre permet de rendre plus faciles les recherches des autres membres.

      Les titres de type "besoin d'aide" ou "problème" ne sont pas tolérés.

      Merci de modifier votre titre. Pour cela, éditez le premier message de votre sujet.

      (titre originel : probleme d'envoie de requete php)

      • Partager sur Facebook
      • Partager sur Twitter

      Pas d'aide concernant le code par MP, le forum est là pour ça :)

        21 janvier 2023 à 23:28:23

        Hello, 

        Ta variable $db sur laquelle tu appelles la fonction prepare n'est qu'une simple chaîne de caractère. D'où l'erreur "Fatal error: Uncaught Error: Call to a member function prepare() on string"

        Il faut que tu utilises les fonctions PDO sur l'objet PDO que tu as créé (ligne 11)

        • Partager sur Facebook
        • Partager sur Twitter
          2 février 2023 à 12:12:09

          hippomssc a écrit:

          Hello, 

          Ta variable $db sur laquelle tu appelles la fonction prepare n'est qu'une simple chaîne de caractère. D'où l'erreur "Fatal error: Uncaught Error: Call to a member function prepare() on string"

          Il faut que tu utilises les fonctions PDO sur l'objet PDO que tu as créé (ligne 11)


          Merci ca a marche
          • Partager sur Facebook
          • Partager sur Twitter
            2 février 2023 à 13:40:05

            "[ERREUR] uncaught error" n'est pas un meilleur titre. Il est même pire, encore moins descriptif que le précédent.
            • Partager sur Facebook
            • Partager sur Twitter

            Pas d'aide concernant le code par MP, le forum est là pour ça :)

            [ERREUR] uncaught error

            × Après avoir cliqué sur "Répondre" vous serez invité à vous connecter pour que votre message soit publié.
            × Attention, ce sujet est très ancien. Le déterrer n'est pas forcément approprié. Nous te conseillons de créer un nouveau sujet pour poser ta question.
            • Editeur
            • Markdown