當前位置: 首頁>>代碼示例>>PHP>>正文


PHP UserIdentity::updatePassword方法代碼示例

本文整理匯總了PHP中UserIdentity::updatePassword方法的典型用法代碼示例。如果您正苦於以下問題:PHP UserIdentity::updatePassword方法的具體用法?PHP UserIdentity::updatePassword怎麽用?PHP UserIdentity::updatePassword使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在UserIdentity的用法示例。


在下文中一共展示了UserIdentity::updatePassword方法的1個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: actionEmailChange

 /**
  * Allows the user to securely change their email address
  * @param  string $key the user's secure key
  */
 public function actionEmailChange($key = null)
 {
     $this->setPageTitle(Yii::t('ciims.controllers.Site', '{{app_name}} | {{label}}', array('{{app_name}}' => Cii::getConfig('name', Yii::app()->name), '{{label}}' => Yii::t('ciims.controllers.Site', 'Change Your Email Address'))));
     $success = false;
     $this->layout = '//layouts/main';
     if ($key == NULL) {
         throw new CHttpException(400, Yii::t('ciims.controllers.Site', 'You are not authorized to change this email address.'));
     }
     $meta = UserMetadata::model()->findByAttributes(array('key' => 'newEmailAddressChangeKey', 'value' => $key));
     if ($meta == NULL || $meta->value != $key) {
         throw new CHttpException(400, Yii::t('ciims.controllers.Site', 'You are not authorized to change this email address.'));
     }
     $threeDays = 259200;
     if (strtotime($meta->created) + $threeDays > time()) {
         try {
             // Delete the associated metadata when this error is thrown
             $meta2 = UserMetadata::model()->findByAttributes(array('key' => 'newEmailAddress', 'user_id' => $meta->user_id));
             $meta2->delete();
             $meta->delete();
         } catch (Exception $e) {
         }
         throw new CHttpException(400, Yii::t('ciims.controllers.Site', 'The request to change your email has expired.'));
     }
     $user = Users::model()->findByPk($meta->user_id);
     if ($user->id != Yii::app()->user->id) {
         throw new CHttpException(400, Yii::t('ciims.controllers.Site', 'You are not authorized to change this email address.'));
     }
     if (Cii::get($_POST, 'password') !== NULL) {
         // Retrieve the user's NEW email address
         $meta = UserMetadata::model()->findByAttributes(array('key' => 'newEmailAddress', 'user_id' => $meta->user_id));
         $identity = new UserIdentity($user->email, $_POST['password']);
         // If we can authenticate that the user wants to change their email address
         if ($identity->authenticate()) {
             // Generate a new hash for the user
             $email = $meta->value;
             $id = $meta->user_id;
             $password = $identity->updatePassword($email, $_POST['password']);
             // Manually update the db via CActiveDataProvider, since Users::beforeSave() will block the request
             try {
                 $ret = Yii::app()->db->createCommand('UPDATE users SET email = :email, password = :password WHERE id = :id')->bindParam(':id', $id)->bindParam(':password', $password)->bindParam(':email', $email)->execute();
                 $success = Yii::t('ciims.controllers.Site', 'Your email address has been sucessfully changes. Please {{login}} again for the changes to take effect.', array('{{login}}' => CHtml::link(Yii::t('ciims.controllers.Site', 'Login'), Yii::app()->createUrl('/login'))));
                 // Kill the users session and force them to re-authenticate with their new credentials.
                 Yii::app()->user->logout();
             } catch (Exception $e) {
                 // This error indicates
                 Yii::app()->user->setFlash('authenticate-error', Yii::t('ciims.controllers.Site', 'The requested email address has already been taken. Please re-submit your request with a new email address.'));
             }
             // Delete the metadata and ignore any errors as they aren't really
             try {
                 $meta->delete();
                 UserMetadata::model()->findByAttributes(array('key' => 'newEmailAddressChangeKey', 'value' => $key))->delete();
                 UserMetadata::model()->findByAttributes(array('user_id' => $id, 'key' => 'newEmailAddressChangeKeyTime'))->delete();
             } catch (Exception $e) {
             }
         } else {
             Yii::app()->user->setFlash('authenticate-error', Yii::t('ciims.controllers.Site', 'We were unable to verify your current password. Please verify your password and try again.'));
         }
     }
     $this->render('emailchange', array('key' => $key, 'success' => $success));
 }
開發者ID:fandikurnia,項目名稱:CiiMS,代碼行數:64,代碼來源:SiteController.php


注:本文中的UserIdentity::updatePassword方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。