当前位置: 首页>>代码示例>>PHP>>正文


PHP Crypto::aes256Decode方法代码示例

本文整理汇总了PHP中Crypto::aes256Decode方法的典型用法代码示例。如果您正苦于以下问题:PHP Crypto::aes256Decode方法的具体用法?PHP Crypto::aes256Decode怎么用?PHP Crypto::aes256Decode使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在Crypto的用法示例。


在下文中一共展示了Crypto::aes256Decode方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的PHP代码示例。

示例1: validateNewEmail

 /**
  * Validate the new email for a user
  */
 public function validateNewEmail()
 {
     $tokenData = json_decode(Crypto::aes256Decode(base64_decode($this->token)), true);
     try {
         if (!$tokenData) {
             // Token format is not valid
             throw new \Exception();
         }
         $user = User::getById($tokenData['userId']);
         if ($user->email !== $tokenData['currentEmail']) {
             // Token does not have the correct email corresponding to the user email
             throw new \Exception();
         }
         if ($tokenData['createTime'] < time() - 86400) {
             // Token has expired
             throw new \Exception();
         }
         // Everything OK, change the user's email address
         $user->set('email', $tokenData['newEmail']);
         $user->save();
         // Disconnect the user
         session_destroy();
         $status = 'success';
         $messageKey = 'main.reset-email-success';
     } catch (\Exception $e) {
         $messageKey = 'main.reset-email-invalid-token';
         $status = 'error';
     }
     $this->addJavaScriptInline('
         require(["app"], function(){
             app.notify("' . $status . '", "' . addcslashes(Lang::get($messageKey), '"') . '");
         });');
     return MainController::getInstance()->main();
 }
开发者ID:elvyrra,项目名称:hawk,代码行数:37,代码来源:UserProfileController.php

示例2: resetPassword

 /**
  * Display and treat the form to reset the user's password
  */
 public function resetPassword()
 {
     $form = new Form(array('id' => 'reset-password-form', 'fieldsets' => array('form' => array(new TextInput(array('name' => 'code', 'required' => true, 'label' => Lang::get($this->_plugin . '.reset-pwd-form-code-label'))), new PasswordInput(array('name' => 'password', 'required' => true, 'label' => Lang::get($this->_plugin . '.reset-pwd-form-password-label'), 'encrypt' => array('\\Hawk\\Crypto', 'saltHash'))), new PasswordInput(array('name' => 'confirmation', 'required' => true, 'compare' => 'password', 'label' => Lang::get($this->_plugin . '.reset-pwd-form-confirmation-label')))), 'submits' => array(new SubmitInput(array('name' => 'valid', 'label' => Lang::get($this->_plugin . '.valid-button'))), new ButtonInput(array('name' => 'cancel', 'label' => Lang::get($this->_plugin . '.cancel-button'), 'href' => App::router()->getUri('login'), 'target' => 'dialog')))), 'onsuccess' => 'app.dialog(app.getUri("login"));'));
     if (!$form->submitted()) {
         return Dialogbox::make(array('title' => Lang::get($this->_plugin . '.reset-pwd-form-title'), 'icon' => 'lock-alt', 'page' => $form));
     } else {
         if ($form->check()) {
             // Check the verficiation code
             if ($form->getData('code') !== Crypto::aes256Decode(App::session()->getData('forgottenPassword.code'))) {
                 $form->error('code', Lang::get($this->_plugin . '.reset-pwd-form-bad-verification-code'));
                 return $form->response(Form::STATUS_CHECK_ERROR);
             }
             try {
                 $user = User::getByEmail(App::session()->getData('forgottenPassword.email'));
                 if ($user) {
                     $user->set('password', $form->inputs['password']->dbvalue());
                     $user->save();
                 } else {
                     return $form->response(Form::STATUS_ERROR, App::session()->getData('forgottenPassword.email'));
                 }
                 return $form->response(Form::STATUS_SUCCESS, Lang::get($this->_plugin . '.reset-pwd-form-success'));
             } catch (\Exception $e) {
                 return $form->response(Form::STATUS_ERROR, Lang::get($this->_plugin . '.reset-pwd-form-error'));
             }
         }
     }
 }
开发者ID:elvyrra,项目名称:hawk,代码行数:30,代码来源:LoginController.php


注:本文中的Crypto::aes256Decode方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。