2015-02-10 42 views
-1

我正在尝试开发表单验证系统。但问题是即使没有用户提供的验证通过所需的数据。找不到问题出在哪里。即使出现错误,PHP表单验证也会通过

这是我的表单验证类

class Validation 
{ 

private $_passed = false, 
     $_errors = array(), 
     $_db = null; 

public function __construct() { 
     $this->_db = DB::getInstance(); 
    } 
public function check($source, $items= array()) { 
     foreach ($items as $item => $rules) { 
      foreach ($rules as $rule => $rule_value) { 
       $value = $source[$item]; 

       if ($rule === 'required' && empty($value)) { 
        $this->addError("{$item} is required"); 
       } else { 

       } 
      } 
     } 

     if (empty($this->_errors)) { 
      $this->_passed = true; 
     } 
     return $this; 

    } 

private function addError($error) { 
     $this->errors[] = $error; 
    } 
public function errors() { 
     return $this->_errors; 
    } 
public function passed() { 
     return $this->_passed; 
    } 
} 

而且这是一个包含HTML表单的形式页面。

require_once 'core/init.php'; 

if (Input::exists()) { 
    $validate = new Validation(); 
    $validation = $validate->check($_POST, array(
     'username' => array(
      'required' => true, 
      'min' => 2, 
      'max' => 20, 
      'unique' => 'users' 
      ), 
     'password' => array(
      'required' => true, 
      'matches' => 'password' 
      ), 
     'password_again' => array(
      'required' => true, 
      'min' => 6 
      ), 
     'name' => array(
      'required' => true, 
      'min' => 2, 
      'max' => 60 
      ), 
     )); 
    if ($validation->passed()) { 
     //register new user 
     echo "passed"; //this passes even though users provides no data 
    } else { 
     print_r($validation->errors()); 
    } 
} 

所以,我得到的是即使用户在不提供任何数据在屏幕上的回波通过。它应该抛出错误,而不是。请帮忙。谢谢

回答

1

addError写在$this->errors,而其他方法使用$this->_errors。 (带下划线)。该_errors阵列将保持为空,所以_passed将在下面的语句设置为true:

if (empty($this->_errors)) { 
    $this->_passed = true; 
} 
+0

像这样的错误很容易被发现。即使没有像xdebug这样的花哨工具。 '_passed'只在一个地方设置为true,并且只有当_errors是空时。 '_errors'也写在一个地方,那个地方正是错误所在。您可以使用'var_dump'来显示有关变量及其内容的详细信息。 – GolezTrol 2015-02-10 20:26:18

+0

非常感谢。我正在快速移动并检查错别字,但找不到任何东西。我会记下你的笔记。感谢你的帮助 – 2015-02-10 20:30:06

相关问题