【问题标题】:OOP Change Password function giving wrong errorOOP 更改密码功能给出错误错误
【发布时间】:2014-07-03 22:42:13
【问题描述】:

我确定我在这里的某个地方犯了一个非常愚蠢的错误 - 所以我正在创建这个更改密码表单并在 OOP 上使用了一个非常糟糕的尝试 - 到目前为止,我没有任何“更改密码” ' 代码,因为我试图先解决错误。

所以,我的问题是 - 当我提交表单时,我收到错误“请填写每个字段!”尽管事实上所有三个字段都已完成。再说一次,我确定我犯了一个非常愚蠢的错误,但我可以在你的帮助下做到!提早提! :)

表单页面顶部的代码

if (empty($_POST) === false) {

  $password = trim($_POST['password']);
  $newpassword = trim($_POST['newpassword']);
  $confpassword = trim($_POST['confnewpassword']);
  $id = $_SESSION['id'];

  if (empty($password) === true || empty($newpassword) === true || empty($confnewpassword) === true) {
    $errors[] = 'Please fill out each field!';
  } else if ($users->current_password($password) === false) {
    $errors[] = 'Current password is incorrect!';
  } else if ($newpassword != $confpassword) {
    $errors[] = 'New password and Confirm password do not match!';
  } else if ($password == $newpassword){
    $errors[] = 'You cannot change your password to your existing password';
  }else {
      $errors[] = 'Password Changed!';
    }
} 

我的 current_password 函数

public function current_password($password) {

    $id = $_SESSION['id'];

    $query = $this->db->prepare("SELECT `password` FROM `users` WHERE `ID` = ?");
    $query->bindValue(1, $id);

    $enteredpassword == $password;

    try{

        $query->execute();
        $storedpass = $query->fetchColumn();

        if ($storedpass === sha1($enteredpassword)) {
            return true;
        } else {
            return false;
        }

    } catch (PDOException $e){
        die($e->getMessage());
    }


}

我的 HTML 表单

<form class="form-horizontal" role="form" method="POST">
  <div class="form-group">
    <label class="col-sm-4 control-label">EIN / Username</label>
    <div class="col-sm-8">
      <input class="form-control" id="disabledInput" type="text" placeholder="<?php echo $ein; ?>" disabled>
    </div>
  </div>
  <div class="form-group">
    <label for="inputPassword" class="col-sm-4 control-label">Enter Existing Password</label>
    <div class="col-sm-8">
      <input type="password" class="form-control" name="password" placeholder="Enter Existing Password">
    </div>
  </div>
  <div class="form-group">
    <label for="inputPassword" class="col-sm-4 control-label">Enter New Password</label>
    <div class="col-sm-8">
      <input type="password" class="form-control" name="newpassword" placeholder="Enter New Password">
    </div>
  </div>
  <div class="form-group">
    <label for="inputPassword" class="col-sm-4 control-label">Confirm New Password</label>
    <div class="col-sm-8">
      <input type="password" class="form-control" name="confnewpassword" placeholder="Confirm New Password">
    </div>
  </div>
  <button type="submit" class="btn btn-primary btn-block">Change Password</button>
</form>

【问题讨论】:

  • 最后一个 empty() 检查。您在分配给 $confpassword 时正在检查 $confnewpassword。

标签: php sql forms oop pdo


【解决方案1】:

您的配置密码变量名称是 $confpassword

$confpassword = trim($_POST['confnewpassword']);

你正在使用 $confnewpassword

if (empty($password) === true || empty($newpassword) === true || empty($confnewpassword) === true)

【讨论】:

    猜你喜欢
    • 2015-08-12
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2016-10-02
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多