提交表单时未定义的索引错误

时间:2015-08-19 06:13:23

标签: php forms validation undefined-index

我忙着 学习 PHP并且一直在按照教程创建一个基本网站,您可以在其中注册并拥有用户帐户/更改密码/更新信息等。

我在你更改密码的部分(我在这个Video的6:10左右)并且我被卡住了。就我而言,我已经完成了他在教程中所做的一切,但是当我提交表单时,我会在下面收到以下错误。请放轻松我,因为我确定我遗漏了一个","或拼写错误,但对于我的生活,我无法找到它。 (注意:当我提交表单时,我会输入我当前的密码,但我收到验证错误,说我没有。)

(更新:将这篇文章标记为重复并指向另一篇文章并不是很有帮助。正如我上面强调的那样,我只是在学习PHP,因此无法解决帖子中的问题并以某种方式将其与我的问题联系起来。)

  

注意:第15行的C:\ wamp \ www \ Movrate \ classes \ Validate.php中的未定义索引:password_current

     

注意:第15行的C:\ wamp \ www \ Movrate \ classes \ Validate.php中的未定义索引:password_current

     

注意:第15行的C:\ wamp \ www \ Movrate \ classes \ Validate.php中的未定义索引:password_new

     

注意:第15行的C:\ wamp \ www \ Movrate \ classes \ Validate.php中的未定义索引:password_new

     

注意:第15行的C:\ wamp \ www \ Movrate \ classes \ Validate.php中的未定义索引:password_new_again

     

注意:第15行的C:\ wamp \ www \ Movrate \ classes \ Validate.php中的未定义索引:password_new_again

     

注意:第15行的C:\ wamp \ www \ Movrate \ classes \ Validate.php中的未定义索引:password_new_again

需要password_current

需要password_new

密码_new_again是必需的

以下是更新密码页面的代码:

    <?php
require_once 'core/init.php';

$user = new User();

if(!$user->isLoggedIn()) {
    Redirect::to('index.php');
}

if(Input::exists()) {
    if(Token::check(Input::get('token'))) {

        $validate = new Validate();
        $validation = $validate->check($_POST, array(
            'password_current' => array(
                'required' => true,
                'min' => 6
            ),
            'password_new' => array(
                'required' => true,
                'min' => 6
            ),
            'password_new_again' => array(
                'required' => true,
                'min' => 6,
                'matches' => 'password_new'
            )
        ));

        if($validation->passed()) {
            // change of password
        } else {
            foreach($validation->errors() as $error) {
                echo $error, '<br>';
            }
        }

    }
}
?>

<form action="" method="post">
    <div class="field">
        <lable for="password_current">Current password</label>
        <input type="password" name="passsword_current" id="password_current">
    </div>

    <div class="field">
        <lable for="password_new">New password</label>
        <input type="password" name="passsword_new" id="password_new">
    </div>

    <div class="field">
        <lable for="password_new_again">New password again</label>
        <input type="password" name="passsword_new_again" id="password_new_again">
    </div>

    <input type="submit" value="Change">
    <input type="hidden" name="token" value="<?php echo Token::generate(); ?>">
</form>

以下是我的验证类的代码:

<?php
class Validate {
    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 = trim($source[$item]);
                $item = escape($item);

                if($rule === 'required' && empty($value)) {
                    $this->addError("{$item} is required");
                } else if(!empty($value)) {
                    switch($rule) {
                        case 'min':
                            if(strlen($value) < $rule_value) {
                                $this->addError("{$item} must be a minimum of {$rule_value} characters.");
                            }
                        break;
                        case 'max':
                            if(strlen($value) > $rule_value) {
                                $this->addError("{$item} must be a maximum of {$rule_value} characters.");
                            }
                        break;
                        case 'matches':
                            if($value != $source[$rule_value]) {
                                $this->addError("{$rule_value} must match {$item}");
                            }
                        break;
                        case 'unique':
                            $check = $this->_db->get($rule_value, array($item, '=', $value)); 
                            if($check->count()) {
                                $this->addError("{$item} already exists.");
                            }
                        break;
                    }
                }

            }
        }

        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;
    }

}

3 个答案:

答案 0 :(得分:1)

我相信您上面发布了错误的“更新密码”页码。您已经发布了只包含一个字段“name”的表单的代码。但是输出响应,验证类,视频以及您说“我输入当前密码”这一事实表明您已经在某处创建了更新密码,但您必须刚刚在上面发布了错误的页面代码。可能想要仔细检查并发布最新/正确的页面代码。您需要确保输入字段都存在于表单中。

如果无法看到该页面/代码,您可能会收到通知,因为您的视频演示器的error_reporting级别不同。您可以通过替换第15行

来正确检查验证类中的数组值,从而防止出现此通知
$value = trim($source[$item]);

用这个:

$value = isset($source[$item]) ? trim($source[$item]) : '';

值得一试。

答案 1 :(得分:0)

据我所知,你在表单中缺少输入字段 添加缺失的输入。

在表单提交后检查发布的数据并查看缺少的内容。

var_dump($_POST);

将输入名称改为passsword_ ..更改密码_ 将filedname与验证规则名称匹配。你应该没问题。

答案 2 :(得分:0)

如果你正在学习,你可以