手机版
你好,游客 登录 注册
背景:
阅读新闻

Yii2 实现修改密码功能

[日期:2015-07-19] 来源:Linux社区  作者:personalnote [字体: ]

主要难点:

1、密码加密

  YII2对密码加密生成的结果是不同的,即用相同的初始密码在不同时间得到的加密结果不同,所以我们不能用常用的方法去验证密码是否正确(将密码加密后与数据库中的密码相比较)。YII2有自己的加密以及密码验证流程。

  加密 $hash = Yii::$app->getSecurity()->generatePasswordHash('123456']);

  验证 Yii::$app->getSecurity()->validatePassword('123456', $hash),返回true或false

2、返回信息处理

  Yii::$app->session->setFlash('contact','旧密码错误');//设置 flash

  return $this->goBack();                 //页面转跳 

  Yii::$app->session->getFlash('contact');       //获取 flash  

public function actionPassword(){
        $model=new PasswordForm;
        $request = YII::$app->request;

        if($request->isPost){
            $p = $request->post('PasswordForm');
            $id = YII::$app->user->id;
            $admin=  Admin::findIdentity($id);
            $password = $admin->password;
            if(Yii::$app->getSecurity()->validatePassword($p['password'], $password)){
                if($p['pass1'] == $p['pass2']){
                    $newPass = Yii::$app->getSecurity()->generatePasswordHash($p['pass1']);
                    $connection = \Yii::$app->db;
                    $r = $connection->createCommand()->update('admin', ['password' => $newPass], 'id='.$id)->execute();
                    if($r){
                        Yii::$app->user->logout();
                        return $this->goHome();
                    }else{
                        return $this->goBack();
                    }
                }
            }else{
                Yii::$app->session->setFlash('contact','旧密码错误');
                return $this->redirect(array('site/password'));
            }
        }else{
            return $this->render('password',['model'=>$model]);
        }

    }

代码优化:主要优化细节如下

  1、将控制器中的主要逻辑代码移入模型中

  2、优化数据库操作

控制器中:

public function actionPassword(){
        $model=new PasswordForm;
        $request = YII::$app->request;

        if($request->isPost && $model->load(Yii::$app->request->post()) && $model->changePassword()){
            Yii::$app->user->logout();
            return $this->goHome();
        }else{
            return $this->render('password',['model'=>$model]);
        }
    }

模型中:

public function changePassword(){
        $id = YII::$app->user->id;
        $admin=  Admin::findIdentity($id);
        $password = $admin->password;
        if(Yii::$app->getSecurity()->validatePassword($this->password, $password)){
            if($this->pass1 == $this->pass2){
                $newPass = Yii::$app->getSecurity()->generatePasswordHash($this->pass1);
                $admin->password = $newPass;
                if($admin->save()){
                    return true;
                }else{
                    return false;
                }
            }else{
                Yii::$app->session->setFlash('contact','两次新密码不相等');
                return false;
            }
        }else{
            Yii::$app->session->setFlash('contact','旧密码错误');
            return false;
        }
    }

Yii 用户登陆机制  http://www.linuxidc.com/Linux/2015-01/111602.htm

Yii中引入js和css文件  http://www.linuxidc.com/Linux/2015-01/111603.htm

Yii 不完全解决方案  http://www.linuxidc.com/Linux/2015-01/111606.htm

Yii CGridView 基本使用 http://www.linuxidc.com/Linux/2015-01/111607.htm

Yii框架分布式缓存的实现方案 http://www.linuxidc.com/Linux/2015-02/113828.htm

Yii 的详细介绍请点这里
Yii 的下载地址请点这里

本文永久更新链接地址http://www.linuxidc.com/Linux/2015-07/120137.htm

linux
相关资讯       Yii  Yii2 
本文评论   查看全部评论 (0)
表情: 表情 姓名: 字数

       

评论声明
  • 尊重网上道德,遵守中华人民共和国的各项有关法律法规
  • 承担一切因您的行为而直接或间接导致的民事或刑事法律责任
  • 本站管理人员有权保留或删除其管辖留言中的任意内容
  • 本站有权��网站内转载或引用您的评论
  • 参与本评论即表明您已经阅读并接受上述条款