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 :

Page d'inscription - Ecriture dans la BDD


Sujet :

PHP & Base de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Homme Profil pro
    Étudiant
    Inscrit en
    Mars 2018
    Messages
    171
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Maine et Loire (Pays de la Loire)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mars 2018
    Messages : 171
    Par défaut Page d'inscription - Ecriture dans la BDD
    Salut a tous,

    Je suis en train de creer une page d'inscription pour mon site. J'ai repris un tuto sur lequel j'ai deja bien galere mais la j'ai de nouveau un soucis que je n'arrive pas a regler.

    J'ai un formulaire dans lequel j'insere mes donnees et je traite les erreurs (de saisie).
    Cependant, au moment d'envoyer mon formulaire, j'ai bien la confirmation de l'inscription (ou l'affichage des erreurs si il y en a) mais le code qui est suppose ecrire les donnees dans la BDD ne fait pas effet. Le voici:

    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
     
    if ($i==0) //si pas d'erreur on rentre ici
     {
    	echo'<h1>Inscription terminée</h1>';
    	echo'<p>Bienvenue '.stripslashes(htmlspecialchars($_POST['pseudo'])).' vous êtes maintenant inscrit sur le site Bet&Win</p>
    	<p>Cliquez <a href="/Bet&Win/index.php">ici</a> pour revenir à la page d\'accueil</p>';
     
     
    	$query=$bdd->prepare('INSERT INTO joueur (pseudoJoueur, password, mailJoueur,             
    	civilitecontact, phoneJoueur, idnationalite, nomJoueur, prenomJoueur)
    	VALUES (:pseudo, :pass, :email, :civilitecontact, :phoneJoueur, :idnationalite, :nomJoueur, :prenomJoueur)');
     
    	$query->bindValue(':pseudo', $pseudo, PDO::PARAM_STR);
    	$query->bindValue(':pass', $pass, PDO::PARAM_STR);
    	$query->bindValue(':email', $email, PDO::PARAM_STR);
    	$query->bindValue(':civilitecontact', $civilitecontact, PDO::PARAM_STR);
    	$query->bindValue(':phoneJoueur', $phoneJoueur, PDO::PARAM_STR);
    	$query->bindValue(':idnationalite', $idnationalite, PDO::PARAM_STR);
    	$query->bindValue(':nomJoueur', $nomJoueur, PDO::PARAM_STR);
    	$query->bindValue(':prenomJoueur', $prenomJoueur, PDO::PARAM_STR);
    	$query->execute();
     
    	//Et on définit les variables de sessions
    	$_SESSION['pseudo'] = $pseudo;
    	//$_SESSION['id'] = $bdd->lastInsertId(); ;
    	//$_SESSION['level'] = 2;
    	$query->CloseCursor();
    }
    Voici la table de ma bdd correspondant:

    Nom : 1523548308191_bdd.jpg
Affichages : 725
Taille : 151,0 Ko

    Voila si vous voyez d'ou vient l'erreur je vous serais tres reconnaissant, bonne fin de journee

  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 : 59
    Localisation : France, Paris (Île de France)

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

    Informations forums :
    Inscription : Juin 2008
    Messages : 2 129
    Billets dans le blog
    8
    Par défaut
    Tu as commencé par vérifier que ton PDO est bon ?

    Etape 1 et 2 du 1er message de ce fil :

    https://www.developpez.net/forums/d1...acilement-pdo/

    Tu n'as pas testé ta requête dans un PHPmyadmin.
    Etape 3 du lien ci dessus.
    PDO, une soupe et au lit !
    Partir de la fin est un bon moyen de retrouver son chemin. Bibi - 2020

  3. #3
    Membre confirmé
    Homme Profil pro
    Étudiant
    Inscrit en
    Mars 2018
    Messages
    171
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Maine et Loire (Pays de la Loire)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mars 2018
    Messages : 171
    Par défaut
    Salut merci pour ta reponse,

    Mon PDO fonctionne avec le reste du site (notement pour lire ma bdd):

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
     <?php
        try
        {
          //Connexion a la BDD
          $bdd = new PDO('mysql:host=localhost;dbname=betandwin;charset=utf8', 'root', 'network');
        }
        catch (Exception $e) //Gestion des erreurs
        {
          die('Erreur : '.$e->getMessage());
        }
    ?>
    Pour les tests je verrais ca un peu plus tard la je taf sur autre chose mais etant donne que j'ai pu lire des donnees de ma bdd je devrais pouvoir ecrire sans probleme ?

    Moi ce qui me pose probleme c'est la syntaxe du code que j'ai poste, genre les variables avec : devant c'est faisable ca ?

    (desole pour les accent en moins clavier qwerty oblige)

  4. #4
    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 : 59
    Localisation : France, Paris (Île de France)

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

    Informations forums :
    Inscription : Juin 2008
    Messages : 2 129
    Billets dans le blog
    8
    Par défaut
    Moi je te dis, fais les choses dans l'ordre.
    Quand tu nous donnes une requête d'insertion qui ne peut pas marcher, fais moi confiance, et va voir pourquoi dans phpmyadmin.
    Pas la peine de sauter les étapes.

    https://www.developpez.net/forums/d1.../#post10166121
    PDO, une soupe et au lit !
    Partir de la fin est un bon moyen de retrouver son chemin. Bibi - 2020

  5. #5
    Membre confirmé
    Homme Profil pro
    Étudiant
    Inscrit en
    Mars 2018
    Messages
    171
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Maine et Loire (Pays de la Loire)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mars 2018
    Messages : 171
    Par défaut
    Oui ok pas de soucis je le ferais des que possible et je te tiens au courant, merci pour ton aide

  6. #6
    Membre confirmé
    Homme Profil pro
    Étudiant
    Inscrit en
    Mars 2018
    Messages
    171
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Maine et Loire (Pays de la Loire)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mars 2018
    Messages : 171
    Par défaut
    Bonjour, donc j'ai essaye de faire les etapes 1 et 2 mais je crois que je m'y suis mal pris quelque part.

    J'ai mis le fichier Connexion_db.class.php ici:
    Nom : winscp.jpg
Affichages : 588
Taille : 250,6 Ko

    Avec le code suivant:
    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
    <?php
    class Connexion_db{
    	protected $name='betandwin';
    	protected $options='';
     
    	public function __construct($name){
    		$this->name=$name;
    		$this->options = array(
    			PDO::MYSQL_ATTR_INIT_COMMAND => "SET NAMES utf8",
    			PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION//mode dev par exemple
    		);	
    	}
     
    	public function retour_pdo(){
    		$dsn='mysql:localhost;dbname='.$this->name;
    		$login='root';
    		$mdp='network';
    		$pdo=new PDO($dsn,$login,$mdp,$this->options);
    		return $pdo;
    	}
    }
    ?>
    Ensuite pour l'etape 2 j'ai cree le fichier test.php ici:
    Nom : winscp2.jpg
Affichages : 613
Taille : 256,1 Ko

    Avec le code suivant:
    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
    <?php
    //si vous faites un new sur n'importe quelle classe qui se trouve dans le répertoire classes
    //il ira chercher ça tout seul !
    spl_autoload_register(function ($class) {
        include './classes/' . $class . '.class.php';
    });
    //simple objet
    $o_db=new Connexion_db('betandwin');
    //le pdo
    $db=$o_db->retour_pdo();
    if($db instanceof PDO){
       echo 'Connexion réussie. On peut continuer !';
       //on pense toujours à la tuer
       unset($db);
    }
    else{
    	echo 'Connexion impossible ! Essaie encore !';
    }
    ?>
    Cependant lorsque j'ouvre test.php j'obtiens:
    Cette page ne fonctionne pas
    Impossible de traiter cette demande via 192.168.56.101 à l'heure actuelle.
    HTTP ERROR 500
    Est ce que ca veut dire que ma connexion echoue ou est ce une erreur php ?

Discussions similaires

  1. Ecriture dans la BDD
    Par nofaceinside dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 10/10/2016, 13h07
  2. [PDO] Ecriture dans la bdd
    Par batala dans le forum PHP & Base de données
    Réponses: 9
    Dernier message: 18/03/2014, 09h06
  3. Ecriture dans une BDD access via Excel
    Par kpitaine dans le forum Macros et VBA Excel
    Réponses: 5
    Dernier message: 03/08/2009, 12h50
  4. Récupérer une date depuis une page ASP dans une BDD
    Par franckrichard57 dans le forum ASP
    Réponses: 2
    Dernier message: 22/03/2007, 11h31
  5. [PHP-JS] page d inscription dans un site
    Par H-bil dans le forum Langage
    Réponses: 5
    Dernier message: 16/06/2006, 02h03

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