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


PHP Security::decrypt方法代碼示例

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


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

示例1: toPHP

 /**
  * Convert string values to PHP integers
  *
  * @param mixed $value The value to convert.
  * @param Driver $driver The driver instance to convert with.
  * @return string|null
  */
 public function toPHP($value, Driver $driver)
 {
     if ($value === null || empty($value)) {
         return null;
     }
     return Security::decrypt(base64_decode($value), Configure::read('Security.key'));
 }
開發者ID:Xety,項目名稱:Xeta,代碼行數:14,代碼來源:EncryptedSecurityType.php

示例2: testMarshal

 /**
  * Test marshalling
  *
  * @return void
  */
 public function testMarshal()
 {
     $this->assertNull($this->type->marshal(null));
     $encrypted = $this->type->marshal('string');
     $this->assertSame(128, strlen($encrypted));
     $decrypted = Security::decrypt(base64_decode($encrypted), Configure::read('Security.key'));
     $this->assertSame('string', $decrypted);
 }
開發者ID:Xety,項目名稱:Xeta,代碼行數:13,代碼來源:EncryptedSecurityTypeTest.php

示例3: decryptToken

 /**
  * Tries to decode, decrypt and unserialize the given token and return the data as an
  * array
  *
  * @param string $token The string token
  * @return array|false
  */
 public function decryptToken($token)
 {
     $tokenData = false;
     $encrypted = base64_decode($token);
     if ($encrypted) {
         $serialized = Security::decrypt($encrypted, Configure::read('Security.cryptKey'));
         $tokenData = unserialize($serialized);
     }
     return $tokenData;
 }
開發者ID:codekanzlei,項目名稱:cake-cktools,代碼行數:17,代碼來源:UserToken.php

示例4: testValueIsAddedToDatabaseWithEncryption

 public function testValueIsAddedToDatabaseWithEncryption()
 {
     $value = '555';
     $store = MapStore::load('2');
     $store->set('access_token', $value);
     $entity = $this->Model->get(['2', 'access_token']);
     $dbValue = stream_get_contents($entity->value);
     $dbValueDecrypted = Security::decrypt($dbValue, Configure::read('Security.key'), Configure::read('Security.salt'));
     $this->assertNotEquals($value, $dbValue);
     $this->assertEquals($value, $dbValueDecrypted);
 }
開發者ID:avinashjoshi,項目名稱:cakephp-mapstore,代碼行數:11,代碼來源:MapStoreTest.php

示例5: _decode

 /**
  * Decodes and decrypts a single value.
  *
  * @param string $value The value to decode & decrypt.
  * @param string|false $encrypt The encryption cipher to use.
  * @return string Decoded value.
  */
 protected function _decode($value, $encrypt)
 {
     if (!$encrypt) {
         return $this->_explode($value);
     }
     $this->_checkCipher($encrypt);
     $prefix = 'Q2FrZQ==.';
     $value = base64_decode(substr($value, strlen($prefix)));
     if ($encrypt === 'rijndael') {
         $value = Security::rijndael($value, $this->_config['key'], 'decrypt');
     }
     if ($encrypt === 'aes') {
         $value = Security::decrypt($value, $this->_config['key']);
     }
     return $this->_explode($value);
 }
開發者ID:maitrepylos,項目名稱:nazeweb,代碼行數:23,代碼來源:CookieComponent.php

示例6: testWriteConfigKeyWithCustomEncryptionKey

 /**
  * Test writing with a custom encryption key using ConfigKey
  *
  * @return void
  */
 public function testWriteConfigKeyWithCustomEncryptionKey()
 {
     $name = 'sampleCookieTest';
     $value = 'some data';
     $encryption = 'aes';
     $prefix = "Q2FrZQ==.";
     $key = 'justanotherencryptionkeyjustanotherencryptionkey';
     $this->Cookie->configKey($name, compact('key', 'encryption'));
     $this->Cookie->write($name, $value);
     $cookie = $this->Controller->response->cookie($name);
     $this->assertEquals($value, Security::decrypt(base64_decode(substr($cookie['value'], strlen($prefix))), $key));
 }
開發者ID:rashmi,項目名稱:newrepo,代碼行數:17,代碼來源:CookieComponentTest.php

示例7: decrypt

 /**
  * Decrypt an encrypted value
  * @param type $cryptedValue Value to be decrypted
  * @return type Decrypted value
  */
 public function decrypt($cryptedValue)
 {
     if (is_resource($cryptedValue)) {
         $cryptedValue = stream_get_contents($cryptedValue);
     }
     return Security::decrypt($cryptedValue, $this->config('key'), $this->config('salt'));
 }
開發者ID:lorenzo,項目名稱:cakephp-cipher-behavior,代碼行數:12,代碼來源:CipherBehavior.php

示例8: _decrypt

 /**
  * Decrypt a base64 encoded string
  *
  * @param string $value string to decrypt
  * @return bool|string
  */
 protected function _decrypt($value)
 {
     if (empty($value)) {
         return false;
     }
     return Security::decrypt(base64_decode($value), $this->_encryptionKey());
 }
開發者ID:andrej-griniuk,項目名稱:cakephp-two-factor-auth,代碼行數:13,代碼來源:FormAuthenticate.php

示例9: testEngineEquivalence

 /**
  * Test that values encrypted with open ssl can be decrypted with mcrypt and the reverse.
  *
  * @return void
  */
 public function testEngineEquivalence()
 {
     $this->skipIf(!defined('MCRYPT_RIJNDAEL_128'), 'This needs mcrypt extension to be loaded.');
     $restore = Security::engine();
     $txt = "Obi-wan you're our only hope";
     $key = 'This is my secret key phrase it is quite long.';
     $salt = 'A tasty salt that is delicious';
     Security::engine(new Mcrypt());
     $cipher = Security::encrypt($txt, $key, $salt);
     $this->assertEquals($txt, Security::decrypt($cipher, $key, $salt));
     Security::engine(new OpenSsl());
     $this->assertEquals($txt, Security::decrypt($cipher, $key, $salt));
     Security::engine(new OpenSsl());
     $cipher = Security::encrypt($txt, $key, $salt);
     $this->assertEquals($txt, Security::decrypt($cipher, $key, $salt));
     Security::engine(new Mcrypt());
     $this->assertEquals($txt, Security::decrypt($cipher, $key, $salt));
 }
開發者ID:Slayug,項目名稱:castor,代碼行數:23,代碼來源:SecurityTest.php

示例10: testEngineEquivalence

 /**
  * Test that values encrypted with open ssl can be decrypted with mcrypt and the reverse.
  *
  * @return void
  */
 public function testEngineEquivalence()
 {
     $restore = Security::engine();
     $txt = "Obi-wan you're our only hope";
     $key = 'This is my secret key phrase it is quite long.';
     $salt = 'A tasty salt that is delicious';
     Security::engine(new Mcrypt());
     $cipher = Security::encrypt($txt, $key, $salt);
     $this->assertEquals($txt, Security::decrypt($cipher, $key, $salt));
     Security::engine(new OpenSsl());
     $this->assertEquals($txt, Security::decrypt($cipher, $key, $salt));
     Security::engine(new OpenSsl());
     $cipher = Security::encrypt($txt, $key, $salt);
     $this->assertEquals($txt, Security::decrypt($cipher, $key, $salt));
     Security::engine(new Mcrypt());
     $this->assertEquals($txt, Security::decrypt($cipher, $key, $salt));
 }
開發者ID:kk-kahle,項目名稱:CI-VZ,代碼行數:22,代碼來源:SecurityTest.php

示例11: _decode

 /**
  * Decodes and decrypts a single value.
  *
  * @param string $value The value to decode & decrypt.
  * @return string Decoded value.
  */
 protected function _decode($value)
 {
     $prefix = 'Q2FrZQ==.';
     $pos = strpos($value, $prefix);
     if ($pos === false) {
         return $this->_explode($value);
     }
     $value = base64_decode(substr($value, strlen($prefix)));
     if ($this->_config['encryption'] === 'rijndael') {
         $plain = Security::rijndael($value, $this->_config['key'], 'decrypt');
     }
     if ($this->_config['encryption'] === 'aes') {
         $plain = Security::decrypt($value, $this->_config['key']);
     }
     return $this->_explode($plain);
 }
開發者ID:ripzappa0924,項目名稱:carte0.0.1,代碼行數:22,代碼來源:CookieComponent.php

示例12: decrypt

 /**
  * {@inheritdoc}
  */
 public function decrypt($cipher)
 {
     return Security::decrypt($cipher, $this->__key);
 }
開發者ID:UseMuffin,項目名稱:Crypt,代碼行數:7,代碼來源:DefaultStrategy.php

示例13: _decode

 /**
  * Decodes and decrypts a single value.
  *
  * @param string $value The value to decode & decrypt.
  * @param string|false $encrypt The encryption cipher to use.
  * @param string|null $key Used as the security salt if specified.
  * @return string Decoded value.
  */
 protected function _decode($value, $encrypt, $key)
 {
     if (!$encrypt) {
         return $this->_explode($value);
     }
     $this->_checkCipher($encrypt);
     $prefix = 'Q2FrZQ==.';
     $value = base64_decode(substr($value, strlen($prefix)));
     if ($key === null) {
         $key = $this->_getCookieEncryptionKey();
     }
     if ($encrypt === 'rijndael') {
         $value = Security::rijndael($value, $key, 'decrypt');
     }
     if ($encrypt === 'aes') {
         $value = Security::decrypt($value, $key);
     }
     return $this->_explode($value);
 }
開發者ID:tgr0ss,項目名稱:cakephp,代碼行數:27,代碼來源:CookieCryptTrait.php

示例14: testDecryptInvalidData

 /**
  * Test that empty data cause errors
  *
  * @expectedException \Cake\Error\Exception
  * @expectedExceptionMessage The data to decrypt cannot be empty.
  * @return void
  */
 public function testDecryptInvalidData()
 {
     $txt = '';
     $key = 'This is a key that is long enough to be ok.';
     Security::decrypt($txt, $key);
 }
開發者ID:ripzappa0924,項目名稱:carte0.0.1,代碼行數:13,代碼來源:SecurityTest.php

示例15: tfa

 /**
  * Ask to the user the 2FA code and verify it.
  *
  * @return \Cake\Network\Response|void
  */
 public function tfa()
 {
     if ($this->Auth->user()) {
         return $this->redirect($this->Auth->redirectUrl());
     }
     if ($this->request->is('post')) {
         $this->loadModel('UsersTwoFactorAuth');
         $id = $this->Cookie->read('CookieTfa');
         if (empty($id) || $id == false) {
             $this->Cookie->delete('CookieTfa');
             return $this->redirect($this->Auth->config('loginAction'));
         }
         try {
             $id = Security::decrypt(base64_decode($id), Configure::read('Security.key'));
         } catch (\Exception $e) {
             $this->Flash->error(__('The link used for the Two-factor Authentication is incorrect.'));
             return $this->redirect($this->Auth->config('loginAction'));
         }
         $userTfa = $this->UsersTwoFactorAuth->find()->where(['user_id' => $id])->first();
         $tfa = new TwoFactorAuth('Xeta');
         $isAuthorized = false;
         $recoveryCodeUsed = false;
         if ($tfa->verifyCode($userTfa->secret, $this->request->data['code']) === true && $this->request->data['code'] !== $userTfa->current_code) {
             $isAuthorized = true;
             //Check recovery code and verify if the recovery code is not already used.
         } elseif ($userTfa->recovery_code === $this->request->data['code'] && $userTfa->recovery_code_used == false && $this->request->data['code'] !== $userTfa->current_code) {
             $isAuthorized = true;
             $recoveryCodeUsed = true;
         }
         if ($isAuthorized === true) {
             $data = ['session' => $this->request->clientIp() . $this->request->header('User-Agent') . gethostbyaddr($this->request->clientIp()), 'current_code' => $recoveryCodeUsed === true ? 'recovery' : $this->request->data['code'], 'recovery_code_used' => $recoveryCodeUsed === true ? 1 : $userTfa->recovery_code_used];
             $this->UsersTwoFactorAuth->patchEntity($userTfa, $data);
             $this->UsersTwoFactorAuth->save($userTfa);
             //Login the user.
             $userLogin = $this->Users->find()->where(['id' => $id])->hydrate(false)->first();
             unset($userLogin['password']);
             $this->_handleLogin($userLogin);
             $this->Cookie->delete('CookieTfa');
             //Logs Event.
             $this->eventManager()->attach(new Logs());
             $event = new Event('Log.User', $this, ['user_id' => $userLogin['id'], 'username' => $userLogin['username'], 'user_ip' => $this->request->clientIp(), 'user_agent' => $this->request->header('User-Agent'), 'action' => '2FA.recovery_code.used']);
             $this->eventManager()->dispatch($event);
             return $this->redirect(['controller' => 'pages', 'action' => 'home']);
         } else {
             $this->Flash->error(__('Two-factor secret verification failed. Please verify your code and try again.'));
         }
     }
     $id = $this->Cookie->read('CookieTfa');
     if (empty($id) || $id == false) {
         $this->Cookie->delete('CookieTfa');
         return $this->redirect($this->Auth->config('loginAction'));
     }
 }
開發者ID:Xety,項目名稱:Xeta,代碼行數:58,代碼來源:UsersController.php


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