首页 文章

yii框架中的电子邮件验证

提问于
浏览
1

我想在用户点击随机生成的网址时验证用户 .

给我这两个过程的解决方案 .

1.从URL请求获取哈希(字符串和数字)的URL管理器配置规则是什么?

2.如何将URL中的哈希值与Controller / Action中数据库中的哈希值进行比较?

发送电子邮件的代码(工作正常)

protected function afterSave()
 {
$activation_url = Yii::app()->createAbsoluteUrl('SignUp/Activate',array('activate_link'=>$this->activate_link));
Yii::import('ext.yii-mail.YiiMailMessage');
$message = new YiiMailMessage;
$message->setBody($activation_url);
$message->subject = 'Hello hell';
$message->addTo($this->email);
$message->from = Yii::app()->params['adminEmail'];
Yii::app()->mail->send($message);
return true;
 }

控制器代码

public function actionActivate($activation) {
$model= Signup::model()->findByAttributes(array(
  'activate_link' => $activation
));
if ($model === null)
    $this->redirect('index.php');

else 
   $model->user_status = 1;
$model->save();
$this->redirect('index.php');
//redirect / flash / login whatever

}

和当前的URLManager配置

'urlManager'=>array(
        'urlFormat'=>'path',
        'showScriptName'=>false,
        'rules'=>array(
            '<controller:\w+>/<id:\d+>' => '<controller>/view',
            '<controller:\w+>/<action:\w+>/<id:\d+>' => '<controller>/<action>',
            '<controller:\w+>/<action:\w+>' => '<controller>/<action>',

        ),
    ),

1 回答

  • 0

    如图所示,在您的Url管理器中进行更改

    'urlManager'=>array(
    //HK_DEVELOPER NR:CHANGED TO GET TO GET THE URL IN DESIRED FORMAT
        'urlFormat'=>'get',
        'rules'=>array(
            '<controller:\w+>/<id:\d+>'=>'<controller>/view',
            '<controller:\w+>/<action:\w+>/<id:\d+>'=>'<controller>/<action>',
            '<controller:\w+>/<action:\w+>'=>'<controller>/<action>',
        ),
    ),
    

    示例确认操作使用url中的密钥以get参数的格式发送电子邮件,并按照我在passkey中的操作获取该密钥

    public function actionConfirm(){
            //HK_DEVELOPER_NR:This action will confirm the user and change status from not authorize to authorized
            $passkey=$_GET['key'];
            $details=User::model()->findByAttributes(array('confirmationCode'=>$passkey));
            if(count($details)>=1)
            {
                if($details['userStatusId']==2){
                    //CHECK IF AUTHORIZED REDIRECT TO PROFILE VIEW
                    $url=Yii::app()->createUrl('site/login&joinbdp=false');
                    $this->redirect($url);//USER CLICKS ON THE REGISTERATION LINK TWICE
                }else{
                    $register=new Registerationconf;
                    $value=$details['userId'];
                    $register->userId=$value;
                    $register->IPAddress=Yii::app()->request->userHostAddress;
                    $register->confirmationTime=new CDbExpression('NOW()');
                    $register->save();
                    //CHANGE STATUS FROM NOT AUTHORIZED TO AUTHORIZED
                    $post=User::model()->updateAll(array('userStatusId'=>'2'), 'confirmationCode=:confirmationCode',array(':confirmationCode'=>$passkey));
                    $this->render('sucess');
                }
            }else {
                //IF USER IS REMOVED AND TRIES TO ACTIVATE THE LINK AGAIN
                echo "Please use valid URL. ";
            }
        }
    

相关问题