2012-07-12 111 views
1

假設與數據庫的連接以及對錶和單元格的所有引用都是正確的......我怎麼能得到這樣的工作?PHP - 使用類獲取用戶信息

class User 
{ 

    private $_display; 
    private $_email; 

    public function __construct($username) 
    { 

     $fetch_user = mysql_query("SELECT * FROM `registered_users` WHERE `user_name`='$username'"); 
     $fetch_user = mysql_fetch_array($fetch_user); 

     $this->_display = $fetch_user['user_display']; 
     $this->_email = $fetch_user['user_email']; 
    } 

} 
$person1 = new User('username'); 
echo "Information: " . print_r($person1, TRUE); 

問題是它返回什麼都沒有。調試時不會拋出錯誤或任何東西。它是可行的方法嗎? :S

+2

** **警告,你的代碼*可能*容易受到SQL注入式攻擊 – 2012-07-12 20:23:46

+0

什麼不起作用?你想要發生什麼?爲你的問題增加一些特殊性,這樣我們可以給出更好的答案。 – Jon 2012-07-12 20:24:33

+1

'$ person1 - > _ display; $ person1 - > _ email;'應該打印你想要的內容 – DarthVader 2012-07-12 20:24:51

回答

0

這裏是大致我會做什麼:

<?php 

    class User{ 

    private $username; 
    private $data; 

    public function __construct($username){ 
     $this->username = $username; 
     if($this->valid_username()){ 
     $this->load(); 
     } 
    } 

    private function load(){ 
     // Let's pretend you have a global $db object. 
     global $db; 
     $this->data = $db->query('SELECT * FROM registered_users WHERE user_name=:username', array(':username'=>$this->username))->execute()->fetchAll(); 
    } 

    public function save(){ 
     // Save $this->data here. 
    } 


    /** 
    * PHP Magic Getter 
    */ 
    public function __get($var){ 
     return $this->data[$var]; 
    } 

    /** 
    * PHP Magic Setter 
    */ 
    public function __set($var, $val){ 
     $this->data[$var] = $val; 
    } 


    private function valid_username(){ 
     //check $this->username for validness. 
    } 

    // This lets you use the object as a string. 
    public function __toString(){ 
     return $this->data['user_name']; 
    } 

    } 

如何使用:

<?php 

    $user = new User('donutdan'); 
    echo $user->name; //will echo 'dan' 
    $user->name = 'bob'; 
    $user->save(); // will save 'bob' to the database 
+0

PHP魔法獲取器和設置器非常適合這些類型的對象。 http://php.net/manual/en/language.oop5.magic.php – donutdan4114 2012-07-13 02:26:35