1

codeigniter でユーザーのパスワードのリセットを実装しようとしています。

ユーザーがメールを送信するフォームを作成し、作成されたトークンを格納する「リセット」テーブルに行を作成し、メールに送信されたリンクにトークンを添付します。

最後のステップは、実際にパスワードをリセットすることです。メールに添付されたトークンを、そのメールに関連付けられたデータベースに保存されているトークンと照合するときに正しい比較を行う方法を理解していません。それが正しい方法であるかどうかもわかりません。

私が持っている現在のコードでは、検証に合格して実際にパスワードをリセットすることができません。これが私のコードです:

これは、トークンを作成して電子メールを送信するためのモデルです。

public function validate_retrieve($data) {

            $query = $this->db->where($data)->get('users', '1');

            foreach ($query->result() as $user)
            {
                $user->email;
                $user->salt;
                $user->id;

            }

            $token = sha1($user->email.$user->salt).dechex($user->id);
            $reset_token = array(
                'token' => $token,
                'email' => $user->email
            );

            $insert = $this->db->insert('reset', $reset_token, '1');
            return $reset_token;
        }

そしてコントローラー:

public function retrieve()
        // REQUEST PASSWORD RESET
        // LOADED WHEN THE FORM IS SUBMITTED OFF THE PASSWORD PAGE AND SENDS THE EMAIL WITH TOKEN AND INSTRUCTIONS
        {
            $this->load->library('form_validation');
            $this->load->library('session');
            $this->form_validation->set_rules('email', 'Email', 'trim|required|valid_email');
            $this->load->model('user_model', 'um');
            $this->load->library('encrypt');
            $this->load->helper('url');
            $submit = $this->input->post('submit');
            $salt = $this->_salt();

            if($submit)
            // IF THE SUBMIT BUTTON IS SET
            {

                // START PROCESS TO CREATE $USER VARIABLE THAT HOLDS WHAT THE USER ENTERED IN THE FORM AND THAT CAN GET CHECKED AGAINST THE DB IN THE MODEL
                $user = $this->um->validate_retrieve(array('email' => $this->input->post('email')));


                // IF THE USER IS CREATED AND CHECKS OUT AND ALL OF THE ERRORS ARE CLEARED ON THE FORM
                if( $user && $this->form_validation->run() == TRUE ) {

                    $domain = "clci.dev/index.php";

                    // CREATE A TOKEN LINK TO SEND TO THE USERS EMAIL THAT EXIST IN THE DB AND WAS ENTERED

                    $token = $user['token'];
                    $link = "http://www.".$domain."/auth/reset/?token=$token";


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

                        $this->email->from('noreply@cysticlife.org', 'CysticLife');
                        $this->email->to($this->input->post('email')); 

                        $this->email->subject('Reset Password');
                        $this->email->message("Please go to the following web address to reset your password:\n\n$link\n\n-Your friends at CysticLife\n\nPlease remember to add the cysticlife.org domain to your address book to ensure that you receive your CysticLife e-Notifications as requested.");  

                        $this->email->send();
                        redirect('auth/success');
                        exit;

                    }
                    $this->form_validation->run() == FALSE;
                    $data['main_content'] = 'auth/password';
                    $this->load->view('includes/templates/main_page_template', $data);
                    $data['email_error'] = 'This email is invalid';
                }
            }

今ここに私が問題を抱えているもの、リセットのモデルがあります:

public function verify_token($token)
          {
            $this->db->where('token', $token);
            $query = $this->db->get('reset');

            if ($query->num_rows() == 1) {

                return TRUE;
            } else {
                return FALSE;

            }
          }

          public function reset_password()
            {
              $salt = $this->_salt();
              $query = $this->db->get('reset', 1);
              $row = $query->row();

              $data = array(
                      'password' => $this->encrypt->sha1($salt . $this->encrypt->sha1($this->input->post('password'))),
                      'salt' => $salt
                    );  
              $this->db->where('email', $row->email);
              $this->db->update('users', $data);
            }

そしてコントローラー:

public function reset_password()
            {
             $this->load->library('form_validation');
             $this->load->library('session');
             $this->load->model('user_model', 'um');
             $this->load->library('encrypt');
             $this->load->helper('url');
             $this->form_validation->set_rules('password', 'Password', 'trim|required'); 
             $this->form_validation->set_rules('password2', 'Confirm Password', 'trim|required|matches[password]');
             $salt = $this->_salt();
             $submit = $this->input->post('submit');


             if($submit) 
             {
              $validToken = $this->um->verify_token($token); 
              if($this->form_validation->run() == TRUE && $validToken == TRUE)
              {

              $this->um->reset_password(array('password' => $this->input->post('password', $salt)));


              $data['main_content'] = 'auth/success';
              $this->load->view('includes/templates/home_page_template', $data);

              }
              $this->form_validation->run() == FALSE;
           $data['main_content'] = 'auth/reset';
           $this->load->view('includes/templates/main_page_template', $data);
             }
            }

私は非常に近いようですが、私は間違いなく立ち往生しています。どんな助けでも大歓迎です。

4

1 に答える 1

1
http://yoursitename.com/reset/[hashcode]

メンバーの電子メールへのリンクを送信し、パスワードがユーザーによってリセットされました。

Web サイトで、ハッシュコードを取得してデータベースと比較します

public function reset($hashcode)
 {
    if($hashcode!=null)
    {
        // compare with db
        // if success 
        // redirect to create new password page
        // or show create new password form
    }
 }
于 2012-12-04T04:03:02.930 に答える