2012-05-11 95 views
0

我只是無法弄清楚..但我有一種感覺,當我拋出異常消息時,問題就在那裏。我在註冊課程中獲得了幾乎相同的代碼。只是給錯誤數組的消息正常地像$ this-> errors [] =「一些錯誤」。php:警告:爲foreach提供的無效參數()

<?php 


class class_login 
{ 
    private $id; 
    private $username; 
    private $password; 
    private $passmd5; 

    private $errors; 
    private $access; 
    private $login; 
    private $ltoken; 

    public function __cunstruct() 
    { 
     $this->errors = array(); 

     $this->login = isset($_POST['login'])? 1:0; 
     $this->access = 0; 
     $this->ltoken = $_POST['ltoken']; 
     $this->id  = 0; 
     $this->username = ($this->login)? $this->filter($_POST['lusername']) : $_SESSION['username']; 
     $this->password = ($this->login)? $this->filter($_POST['lpassword']) : ''; 
     $this->passmd5 = ($this->login)? md5($this->password) : $_SESSION['password']; 

    } 

    public function isLoggedIn() 
    { 
     ($this->login)? $this->verifyPost() : $this->verifySession(); 

     return $this->access; 
    } 

    public function filter($var) 
    { 
     return preg_replace('/[^a-zA-Z0-9]/','',$var); 
    } 

    public function verifyPost() 
    { 
     try 
     { 
      if(!$this->tokenValid()) 
       throw new Exception('Invalid Form Submission!'); 
      if(!$this->isDataValid()) 
       throw new Exception('Ivalid Form Data!'); 
      if(!$this->verifyDatabase()) 
       throw new Exception('Invalid Username/Password!'); 

      $this->access = 1; 
      $this->registerSession(); 
     } 
     catch(Exception $e) 
     { 
      $this->errors[] = $e->getMessage(); 
     } 
    } 

    public function verifySession() 
    { 
     if($this->sessionExist() && $this->verifyDatabase()) 
     $this->access = 1; 
    } 

    public function verifyDatabase() 
    { 
     include('db_connect.php'); 

     $data = mysql_query("SELECT ID FROM users WHERE username = '($this->username)' AND password = '($this->passmd5)'"); 

     if (mysql_num_rows($data)) 
     { 
      list($this->id) = @array_values(mysql_fetch_assoc($data)); 

      return true; 
     } 
     else 
      return false; 

     } 

    public function isDataValid() 
    { 
     return (preg_match('/[^a-zA-Z0-9](5,12)$/', $this->username) && preg_match('/[^a-zA-Z0-9](5,12)$/', $this->password))? 1:0; 
    } 

    public function tokenValid() 
    { 
     return (!isset($_SESSION['ltoken']) || $this->ltoken != $_SESSION['ltoken'])? 0 : 1; 
    } 

    public function registerSession() 
    { 
     $_SESSION['ID']  = $this->id; 
     $_SESSION['username'] = $this->username; 
     $_SESSION['password'] = $this->passmd5; 
    } 

    public function sessionExist() 
    { 
     return (isset($_SESSION['username']) && isset($_SESSION['password']))? 1 : 0; 
    } 

    public function show_errors() 
    { 
     foreach($this->errors as $key=>$value) 
      echo $value."</br>"; 
    } 


} 

?> 
+2

它應該是 - >構造不__cunstruct(),如果它的正確PHP的版本使用的是? – swapnesh

+0

它是__cunstruct(),那不是問題。使用5.3.8。謝謝。 –

+0

nvm我明白你的意思了,謝謝 –

回答

2

該構造函數被稱爲__construct而不是__cunstruct

0

我看到你正在將$ this-> errors設置爲你的__cunstruct函數中的一個數組,但由於它不是__construct,它可能永遠不會被設置。

0

您需要

foreach($this->errors as $key=>$value) 

一個關聯數組,但你有沒有一個。 ($這個 - >錯誤[] = $ E->的getMessage();)

用了一個關聯數組,你必須使用:

foreach($this->errors as $value) 
+0

對於非關聯數組,您仍然可以使用$ key => $ value(在PHP中,所有數組都是真正關聯的)。 $ key只是隱式索引而不是明確的鍵。 – Brian

0
public function __cunstruct() <------ The error is probably here. It is __construct 
    { 
     $this->errors = array(); 

     $this->login = isset($_POST['login'])? 1:0; 
     $this->access = 0; 
     $this->ltoken = $_POST['ltoken']; 
     $this->id  = 0; 
     $this->username = ($this->login)? $this->filter($_POST['lusername']) : $_SESSION['username']; 
     $this->password = ($this->login)? $this->filter($_POST['lpassword']) : ''; 
     $this->passmd5 = ($this->login)? md5($this->password) : $_SESSION['password']; 

    } 

你有一個錯字.... _ 構建,而不是 _construct

相關問題