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 :

[POO] Problème d'accès à une variable privée


Sujet :

Langage PHP

  1. #1
    Membre régulier Avatar de Nadd
    Profil pro
    Étudiant
    Inscrit en
    Septembre 2005
    Messages
    160
    Détails du profil
    Informations personnelles :
    Âge : 35
    Localisation : Belgique

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Septembre 2005
    Messages : 160
    Points : 95
    Points
    95
    Par défaut [POO] Problème d'accès à une variable privée
    Bonjour,

    Code :

    db.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
    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
     
    <?php
    /******************
     x0Konzept : Dev'One
     ******************/
     
    if (!defined('IN'))
    {
    	exit;
    }
     
    class mysql_db
    	{	
    		private $tab_pr = array();
     
    		// oo_add
    		private function oo_add($nom, $valeur)
    			{
    				$this->tab_pr[$nom] = $valeur;
    			}
     
    		// oo_sort
    		function oo_sort($nom)
    			{
    				return $this->tab_pr[$nom];
    			}
     
    		// connect
    		function connect($host, $user, $password, $db)
    			{
    				$this->dbserver = $host;
    				$this->dbuser = $user;
    				$this->dbpassword = $password;
    				$this->dbbase = $db;
     
    				$this->connexion = @mysql_connect($this->dbserver, $this->dbuser, $this->dbpassword);
     
    					if($this->connexion && $this->dbbase != '')
    						{
    							$dbselect = @mysql_select_db("xkonzept", $this->connexion);
     
    							if($dbselect)
    								{
    									return $this->connexion;
    								}
    						}
    			}
     
    		// query_login
    		function sql_query_login($query)
    			{
    				$this->do_query = @mysql_query($query, $this->connexion);
     
    				$result = mysql_num_rows($this->do_query);
     
    				if($result == 1)
    					{
    						$this->al = TRUE;
    						return $this->do_query;
    					}
    				else
    					{
    						return FALSE;
    					}
    			}
     
    		// query
    		function sql_query($query)
    			{
    				$this->do_query = @mysql_query($query, $this->connexion);
     
    				if($this->do_query)
    					{
    						return $this->do_query;
    					}
    			}
     
    		// login_check
    		function login_check($l_username, $l_password)
    			{
    				if(isset($l_username) && isset($l_password))
    					{
    						if(!empty($l_username) && !empty($l_password))
    							{
    								$this->oo_add('username', $l_username);
    								$query = "SELECT ID, username, password FROM devone_users WHERE username='".$l_username."' AND password=md5('".$l_password."')";
     
    								if($this->sql_query_login($query) == TRUE)
    									{
    										return TRUE;
    									}
    								if( $this->sql_query_login($query) == FALSE)
    									{
    										return FALSE;
    									}
    							}
    					}
    			}
     
    		// _sort
    		function _sort($nom)
    			{
    				if(!empty($nom))
    					{
    						if($_SESSION['AUTHX'] == TRUE)
    							{
    								$_return = $this->oo_sort('username');
    								return $_return;
    							}
    						else
    							{
    								return 'Erreur, @1';
    							}
    					}
    				else
    					{
    						return 'Erreur, @2';
    					}
    			}
     
    		// fetchrow
    		function sql_fetchrow($query_id = 0)
    			{
    				if(!$query_id)
    					{
    						$query_id = $this->query_result;
    					}
    				if($query_id)
    					{
    						$this->row[$query_id] = @mysql_fetch_array($query_id);
    						return $this->row[$query_id];
    					}
    				else
    					{
    						return false;
    					}
    			}
    	}
     
    ?>
    header.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
     
    <?php
    /******************
     x0Konzept : Dev'One
     ******************/
     
    if (!defined('IN'))
    {
    	exit;
    }
     
    ?>
    <html>
    <head>
    <title>x0Konzept : Dev'One</title>
    <link rel="stylesheet" type="text/css" href="style.css">
    </head>
    <body>
    <table cellpadding="0" cellspacing="0" width="1000" height="100" class="header_table" align="center">
    <tr>
    <td valign="middle" width="600"><span class="header_titre">x0Konzept : Dev'<font color="#82c9ff">One</font></span></td>
    <td valign="top" width="600"><span class="header_little">
    <div align="right">Vous êtes connecté en tant que : <?php echo "<font color='red'>".$db->oo_sort('username')."</font>"; ?></div></span>
    </td>
    </tr>
    </table>
    Le problème :

    Alors voila mon problème : lorsque j'appelle cette fonction (public) : $db->oo_sort('username'), aucune information ne semble être renvoyée. Pourtant, une valeur à bien été attribuée à 'username' dans mon tableau !

    Si, par exemple, j'introduit "$db->oo_sort('username')" après oo_add dans ma fonction login, alors là, une valeur est renvoyée ! Je ne comprends pas pourquoi :s la valeur d' 'username', ayant été attribué lors de la connexion au site web n'existe plus.

    Que puis-je faire ?

    En vous remerciant d'avance,

    Nadd.

  2. #2
    Expert éminent sénior
    Avatar de mathieu
    Profil pro
    Inscrit en
    Juin 2003
    Messages
    10 393
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 10 393
    Points : 15 754
    Points
    15 754
    Par défaut
    à quel moment est créé l'objet $db et quand est fait le "oo_add('username', ..." ?

  3. #3
    Membre régulier Avatar de Nadd
    Profil pro
    Étudiant
    Inscrit en
    Septembre 2005
    Messages
    160
    Détails du profil
    Informations personnelles :
    Âge : 35
    Localisation : Belgique

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Septembre 2005
    Messages : 160
    Points : 95
    Points
    95
    Par défaut
    Concernant le oo_add :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    function login_check($l_username, $l_password)
    {
    if(isset($l_username) && isset($l_password))
    {
    if(!empty($l_username) && !empty($l_password))
    {
    $this->oo_add('username', $l_username);
    ...
    ...
    l'attribution d'une valeur à 'username' se fait lors de la connexion au site (fct login_check).

    Concernant l'objet :

    Il est crée dans mon fichier principal (common.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
     
    <?php
    /******************
     x0Konzept : Dev'One
     ******************/
     
    if (!defined('IN'))
    {
    	exit;
    }
     
    require('config.php');
    require('date.php');
    require('functions.php');
    require('db.php');
     
    $db = new mysql_db;
    $db->connect($host, $user, $password, $db);
     
    ?>
    Cordialement,

    Nadd.

  4. #4
    Expert éminent sénior
    Avatar de mathieu
    Profil pro
    Inscrit en
    Juin 2003
    Messages
    10 393
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 10 393
    Points : 15 754
    Points
    15 754
    Par défaut
    petite parenthèse pendant que je regarde ton code : tu envoie le nom de la base en dur à la fonction "mysql_select_db" au lieu de lui passer le nom qui se trouve dans la variable

  5. #5
    Membre régulier Avatar de Nadd
    Profil pro
    Étudiant
    Inscrit en
    Septembre 2005
    Messages
    160
    Détails du profil
    Informations personnelles :
    Âge : 35
    Localisation : Belgique

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Septembre 2005
    Messages : 160
    Points : 95
    Points
    95
    Par défaut
    Le problème c'est que lorsque j'envoi le nom de la base de donnée par $this->dbbase, cela ne fonctionne pas pour une raison que j'igniore

  6. #6
    Expert éminent sénior
    Avatar de mathieu
    Profil pro
    Inscrit en
    Juin 2003
    Messages
    10 393
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 10 393
    Points : 15 754
    Points
    15 754
    Par défaut
    ote déjà le "@" pour voir si tu as une erreur

  7. #7
    Membre régulier Avatar de Nadd
    Profil pro
    Étudiant
    Inscrit en
    Septembre 2005
    Messages
    160
    Détails du profil
    Informations personnelles :
    Âge : 35
    Localisation : Belgique

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Septembre 2005
    Messages : 160
    Points : 95
    Points
    95
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    $dbselect = mysql_select_db($this->dbbase, $this->connexion);
    if($dbselect)
    {
    return $this->connexion;
    }
    Ca ne marche toujours pas :s

  8. #8
    Membre régulier Avatar de Nadd
    Profil pro
    Étudiant
    Inscrit en
    Septembre 2005
    Messages
    160
    Détails du profil
    Informations personnelles :
    Âge : 35
    Localisation : Belgique

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Septembre 2005
    Messages : 160
    Points : 95
    Points
    95
    Par défaut
    Une solution en ce qui concerne le tableau privé ?

    ps: J'ai résolu le problème concernant le mysql_select_db.

  9. #9
    Membre régulier Avatar de Nadd
    Profil pro
    Étudiant
    Inscrit en
    Septembre 2005
    Messages
    160
    Détails du profil
    Informations personnelles :
    Âge : 35
    Localisation : Belgique

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Septembre 2005
    Messages : 160
    Points : 95
    Points
    95
    Par défaut
    J'ai trouvé une alternative (sûre ou pas ?) à mon problème : stocker l'ID de l'utilisateur dans la variable $_SESSION.

    Quand il faudra acceder à, par exemple l'username, le script fera appel à une fonction de récupération de donnée : $db->_sort($id,'username') $id étant $_SESSION['USER_ID'].

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    function _sort($id, $champ)
    {
    $query = "SELECT ".$champ." FROM devone_users WHERE ID='".$id."' LIMIT 1";
    $row = $this->sql_fetchrow($this->sql_query($query));
     
    return $row[$champ];
    }

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

Discussions similaires

  1. Problème d'accès à une variable partagée
    Par sebac dans le forum Général Java
    Réponses: 1
    Dernier message: 04/09/2009, 12h11
  2. Problème d'accés à une variable
    Par debo41 dans le forum Flex
    Réponses: 15
    Dernier message: 21/08/2008, 11h36
  3. Accès à une variable privée
    Par jobe dans le forum C++
    Réponses: 2
    Dernier message: 10/11/2007, 20h46
  4. [C#] Problème d'accès à une variable depuis une popup
    Par LE NEINDRE dans le forum ASP.NET
    Réponses: 2
    Dernier message: 03/01/2007, 15h30
  5. Problème d'accès à une variable
    Par khaled.mtibaa dans le forum Langage
    Réponses: 3
    Dernier message: 20/04/2006, 11h39

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