清除密码而不是更新密码/重置密码

时间:2013-09-25 00:16:50

标签: php mysql html5 codeigniter

我试图允许用户更改密码,但不是用新密码替换旧密码,而是删除/清除数据库中的密码字段。我只是测试与db的交互,因此我还没有使用模型。

控制器

<?php
class My_account extends CI_Controller {
    public function index(){
        $this->load->view("vChangePassword");
    }

    public function change_password() {

        $this->load->library('form_validation');

        $this->form_validation->set_rules('cur_password','Current Password','required');
        $this->form_validation->set_rules('new_password','New Password','required');
        $this->form_validation->set_rules('con_password','Confirm Password',          'required[matches[new_password]');
        if ($this->form_validation->run()!= true){
            $this->load->view("vChangePassword");
        } else {
            $sql = $this->db->select("*")->from('users')->where('email',$this->session->userdata('email') )->get();
            foreach($sql->result() as $my_info) {
                $db_password = $my_info->password;
                $email = $my_info->email; 
            }
            if(md5($this->input->post('cur_password'))== $db_password){
                $fixed_password = md5($this->input->post('new_password')); 
                $fixed_password ='password';
                $this->db->where('email', $email)->update('users' ,$fixed_password );

                echo "Password has been updated!" ;    
             } else {
                 echo "Password is incorrect!";
             }
        }


    }
}

?>

我的观点

 <?php
echo form_open(base_url()."index.php/my_account/change_password")?>
<?php echo validation_errors();
?>
<table class=”table table-bordered”>
<tbody>
<tr>
<td><small><?php echo 'Old Password:';?></small></td>
<td><?php echo form_password("cur_password");?></td>
</tr>
<tr>
<td><small><?php echo 'New Password:';?></small></td>
<td><?php echo form_password("new_password");?></td>
</tr>
<tr>
<td><small><?php echo 'Confirm Password:';?></small></td>
<td><?php echo form_password("con_password");?></td>
</tr>
</tbody>
</table>
&nbsp;&nbsp;<div id=”some”style=”position:relative;”><button type=”submit” class=”btn    btn-primary”><i class=” icon-ok-sign icon-white”></i>&nbsp;Submit</button>
<?php
echo form_close();
?>

2 个答案:

答案 0 :(得分:1)

看看以下几行:

$fixed_password = md5($this->input->post('new_password'));
$fixed_password ='password';
$this->db->where('email', $email)->update('users' ,$fixed_password );

您为同一个变量分配了两个不同的值,其中最后一个是将要坚持的值,即$fixed_password将具有值password,而无论用户输入什么,都没有。其次,查看http://ellislab.com/codeigniter/user-guide/database/active_record.html#update中找到的CodeIgniter中ActiveRecord类的文档。从那以后你应该能够弄清楚如何正确调用update()方法,它需要一个关联数组或一个对象作为第二个参数。我建议在这个时候使用一个数组,因为这是最容易的,而且似乎就是你要去的地方。希望它有所帮助!

答案 1 :(得分:0)

$this->db->where('email', $email)->update('users' ,$fixed_password );

这条线看起来不对劲。看起来您更新了用户名而不是密码字段。