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

Langage PHP Discussion :

Récuperer les données de l'utilisateur


Sujet :

Langage PHP

  1. #1
    Futur Membre du Club
    Homme Profil pro
    Etudiant terminale
    Inscrit en
    Juillet 2012
    Messages
    23
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Etudiant terminale

    Informations forums :
    Inscription : Juillet 2012
    Messages : 23
    Points : 9
    Points
    9
    Par défaut Récuperer les données de l'utilisateur
    Bonjours à tous.
    Etant grand débutant en PHP, je viens demander de l'aide pour un probleme que je ne parviens pas à résoudre :

    Pour commencer j'ai une table mysql comme ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    CREATE TABLE IF NOT EXISTS `users` (
      `id` int(11) NOT NULL AUTO_INCREMENT,
      `nom` varchar(35) COLLATE utf8_unicode_ci NOT NULL,
      `prenom` varchar(35) COLLATE utf8_unicode_ci NOT NULL,
      `email` varchar(70) COLLATE utf8_unicode_ci NOT NULL,
      `password` varchar(40) COLLATE utf8_unicode_ci NOT NULL,
      `pseudo` text COLLATE utf8_unicode_ci NOT NULL,
      `signup_date` int(11) NOT NULL,
      `photo` varchar(100) COLLATE utf8_unicode_ci NOT NULL DEFAULT 'image/noimage.png',
      `avatar` varchar(100) COLLATE utf8_unicode_ci NOT NULL DEFAULT 'image/noimage.png',
      `sex` int(11) NOT NULL DEFAULT '0',
      `rank` int(11) NOT NULL DEFAULT '0',
      KEY `id` (`id`)
    ) ENGINE=MyISAM  DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci AUTO_INCREMENT=10 ;
    L'uilisateur se connecte grâce à son mdp et son mail.
    Il est ensuite redirigé vers une page profil.

    Dans cette page : je souhaiterais afficher les valeurs de la table correspondant à l'id de l'utilisateur connecté.
    Sachant que la connexion entraine la creation d'une session contenant son ID
    $_SESSION['userid'])

    Par exemple :
    Bienvenu $nom $avatar $photo

    Voici vos infos :
    $email
    $pseudo
    ...etc

    Il y aurait-il une âme charitable pour m'aider ?

  2. #2
    Rédacteur

    Avatar de Torgar
    Homme Profil pro
    Développeur Web
    Inscrit en
    Août 2007
    Messages
    2 334
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Août 2007
    Messages : 2 334
    Points : 8 040
    Points
    8 040
    Par défaut
    Salut,

    Il faut faire une requête SQL sur ta table `users`, en indiquant les champs que tu souhaites afficher, et une clause WHERE pour limiter la sélection à l'utilisateur actuel.

  3. #3
    Futur Membre du Club
    Homme Profil pro
    Etudiant terminale
    Inscrit en
    Juillet 2012
    Messages
    23
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Etudiant terminale

    Informations forums :
    Inscription : Juillet 2012
    Messages : 23
    Points : 9
    Points
    9
    Par défaut
    J'avais déja essayé ainsi mais la syntaxe me posais probleme

  4. #4
    Rédacteur

    Avatar de Torgar
    Homme Profil pro
    Développeur Web
    Inscrit en
    Août 2007
    Messages
    2 334
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Août 2007
    Messages : 2 334
    Points : 8 040
    Points
    8 040
    Par défaut
    Montre nous ce que tu as fait. On pourra le corriger.

  5. #5
    Futur Membre du Club
    Homme Profil pro
    Etudiant terminale
    Inscrit en
    Juillet 2012
    Messages
    23
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Etudiant terminale

    Informations forums :
    Inscription : Juillet 2012
    Messages : 23
    Points : 9
    Points
    9
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    <?php $id = intval($_GET['id']);
    	$dn = mysql_query('select pseudo, email, nom, avatar, prenom from users where id="'.$id.'"');
    	if(mysql_num_rows($dn)>0)
    	{
    		$dnn = mysql_fetch_array($dn); ?>
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Voici le profil de "<?php echo htmlentities($dnn['username']); ?>" :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Voici son pseudo "<?php echo htmlentities($dnn['pseudo']); ?>
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Voici son avatar <img src="<?php echo htmlentities($dnn['avatar']); ?>">

  6. #6
    Rédacteur

    Avatar de Torgar
    Homme Profil pro
    Développeur Web
    Inscrit en
    Août 2007
    Messages
    2 334
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Août 2007
    Messages : 2 334
    Points : 8 040
    Points
    8 040
    Par défaut
    La colonne `id` est de type entier (int), donc il faut lui donner un entier dans ta clause WHERE, chose dont tu t'assures avec le intval(). Cependant, il ne faut pas entourer la valeur par des quotes dans ta requête car là, tu l'as "converti" en chaine de caractères. Et comparer des entiers avec du texte...

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $dn = mysql_query('SELECT pseudo, email, nom, avatar, prenom FROM users WHERE id='.$id);

  7. #7
    Futur Membre du Club
    Homme Profil pro
    Etudiant terminale
    Inscrit en
    Juillet 2012
    Messages
    23
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Etudiant terminale

    Informations forums :
    Inscription : Juillet 2012
    Messages : 23
    Points : 9
    Points
    9
    Par défaut
    Donc si je veux afficher le pseudo du "connecté" : mon code doit ressembler à cela ?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    <?php $dn = mysql_query('SELECT pseudo, email, nom, avatar, prenom FROM users WHERE id='.$id);
    	 ?>
    Voici son pseudo : <?php echo htmlentities($dnn['pseudo']); ?>
    Enfin jdis ça : ça ne marche pas donc... x)

  8. #8
    Rédacteur

    Avatar de Torgar
    Homme Profil pro
    Développeur Web
    Inscrit en
    Août 2007
    Messages
    2 334
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Août 2007
    Messages : 2 334
    Points : 8 040
    Points
    8 040
    Par défaut
    Ca ne dispense pas de laisser le mysql_fetch_array() puisqu'il faut quand même lire le résultat de la requête. Et de fermer l'accolade du if() une fois toutes les informations affichées. (chose qui n'est pas reportée ici).

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    <?php $id = intval($_GET['id']);
        $dn = mysql_query('select pseudo, email, nom, avatar, prenom from users where id = '. $id);
        if(mysql_num_rows($dn)>0)
        {
            $dnn = mysql_fetch_array($dn);
    ?>
            Voici son pseudo : <?php echo htmlentities($dnn['pseudo']); ?>

  9. #9
    Futur Membre du Club
    Homme Profil pro
    Etudiant terminale
    Inscrit en
    Juillet 2012
    Messages
    23
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Etudiant terminale

    Informations forums :
    Inscription : Juillet 2012
    Messages : 23
    Points : 9
    Points
    9
    Par défaut
    Hum...a titre de simple test : j'ai tapé :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    <?php $id = intval($_GET['id']);
        $dn = mysql_query('select pseudo, email, nom, avatar, prenom from users where id = '. $id);
        if(mysql_num_rows($dn)>0)
        {
            $dnn = mysql_fetch_array($dn);
    ?>
            Voici son pseudo : <?php echo htmlentities($dnn['pseudo']); ?>
    <?php } ?>
    Pas d'erreur mais rien ne s'affiche (il manque le else peut etre ? )

    Merci en tout cas pour le temps que tu m'accorde

  10. #10
    Rédacteur

    Avatar de Torgar
    Homme Profil pro
    Développeur Web
    Inscrit en
    Août 2007
    Messages
    2 334
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Août 2007
    Messages : 2 334
    Points : 8 040
    Points
    8 040
    Par défaut
    C'est qu'il n'y a pas d'entrée dans ta table pour cette condition, sinon il passerait dans ton if.

    Rajoute quelques tests pour être sûr.

    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
    <?php
    $id = intval($_GET['id']);
    if (!empty($id)) {
        $dn = mysql_query('select pseudo, email, nom, avatar, prenom from users where id = '. $id);
     
        if (mysql_num_rows($dn) > 0) {
            $dnn = mysql_fetch_array($dn);
            echo 'Voici son pseudo : ' . htmlentities($dnn['pseudo']) . '<br />';
        }
        else {
            echo 'Pas de correspondances trouvées.';
        }
    }
    else {
        echo 'L\'identifiant n\'est pas défini.';
    }
    ?>

  11. #11
    Futur Membre du Club
    Homme Profil pro
    Etudiant terminale
    Inscrit en
    Juillet 2012
    Messages
    23
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Etudiant terminale

    Informations forums :
    Inscription : Juillet 2012
    Messages : 23
    Points : 9
    Points
    9
    Par défaut
    J'ai le message d'ID non definis :

    Voici ma page complete :
    (hormis l'include pour se connecter à la base de donnée)
    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
    <style>
    div#iduser
    {
    position: fixed;
    bottom: 0px;
    right: 0px;
    font-size: xx-small;
    color: grey;
    }
    </style>
     
    <div id="iduser">
    Votre ID de compte est le n&deg;<?php echo $_SESSION['userid']; ?>
    </div>
     
    <div id="profilinfo">
     
    <?php
    $id = intval($_GET['id']);
    if (!empty($id)) {
        $dn = mysql_query('select pseudo, email, nom, avatar, prenom from users where id = '. $userid);
     
        if (mysql_num_rows($dn) > 0) {
            $dnn = mysql_fetch_array($dn);
            echo 'Voici son pseudo : ' . htmlentities($dnn['pseudo']) . '<br />';
        }
        else {
            echo 'Pas de correspondances trouvées.';
        }
    }
    else {
        echo 'L\'identifiant n\'est pas défini.';
    }
    ?>
    </div>
    Je precise que le div "iduser" m'affiche bien le numéro de l'id.


  12. #12
    Rédacteur

    Avatar de Torgar
    Homme Profil pro
    Développeur Web
    Inscrit en
    Août 2007
    Messages
    2 334
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Août 2007
    Messages : 2 334
    Points : 8 040
    Points
    8 040
    Par défaut
    Si tu veux afficher tes informations, donc de ta session, tu n'as pas besoin d'utiliser GET.

    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
    <style>
    div#iduser {
        position: fixed;
        bottom: 0px;
        right: 0px;
        font-size: xx-small;
        color: grey;
    }
    </style>
     
    <div id="iduser">
        Votre ID de compte est le n&deg;<?php echo $_SESSION['userid']; ?>
    </div>
     
    <div id="profilinfo">
     
    <?php
     
        $dn = mysql_query('select pseudo, email, nom, avatar, prenom from users where id = '. intval($_SESSION['userid']));
     
        if (mysql_num_rows($dn) > 0) {
            $dnn = mysql_fetch_array($dn);
            echo 'Voici son pseudo : ' . htmlentities($dnn['pseudo']) . '<br />';
        }
        else {
            echo 'Pas de correspondances trouvées.';
        }
     
    ?>
    </div>

  13. #13
    Futur Membre du Club
    Homme Profil pro
    Etudiant terminale
    Inscrit en
    Juillet 2012
    Messages
    23
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Etudiant terminale

    Informations forums :
    Inscription : Juillet 2012
    Messages : 23
    Points : 9
    Points
    9
    Par défaut
    Hum... j'ai le message : pas de correspondance trouvée.
    De plus : l'id (valeur du div#userid) ne s'affiche plus.

    Cela viendrais de ma connexion à la base sql ?

    Ma page config.php qui fait l'objet d'un include dans la page précédente :
    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
    //On demarre les sessions
    session_start();
     
    /******************************************************
    ----------------Configuration Obligatoire--------------
    Veuillez modifier les variables ci-dessous pour que l'
    espace membre puisse fonctionner correctement.
    ******************************************************/
     
    //On se connecte a la base de donnee
    mysql_connect('hote', 'identifiant', 'motdepasse');
    mysql_select_db('labasededonnée');
    ?>

  14. #14
    Futur Membre du Club
    Homme Profil pro
    Etudiant terminale
    Inscrit en
    Juillet 2012
    Messages
    23
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Etudiant terminale

    Informations forums :
    Inscription : Juillet 2012
    Messages : 23
    Points : 9
    Points
    9
    Par défaut
    Je retire ce que j'ai dis : il suffit de passer le paramètre par l'URL (http://monsite.com/profil.php?id="numerodel'id")

    Sujet résolu : un GRANNNND merci à Torgar !

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

Discussions similaires

  1. récuperer les données de la fonction data arrival
    Par johnson95 dans le forum VB 6 et antérieur
    Réponses: 3
    Dernier message: 20/06/2006, 10h35
  2. Réponses: 1
    Dernier message: 24/04/2006, 01h55
  3. Récuperer les données d'un FlexGrid pour faire requete SQL
    Par Terminator dans le forum VB 6 et antérieur
    Réponses: 1
    Dernier message: 13/10/2005, 11h26
  4. Récupere les données d'un dataGrid
    Par Terminator dans le forum VB 6 et antérieur
    Réponses: 2
    Dernier message: 11/10/2005, 14h05
  5. [JTable] Comment récuperer les données d'un fichier texte ?
    Par Makunouchi dans le forum Composants
    Réponses: 2
    Dernier message: 03/05/2005, 16h37

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