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


PHP TokenInterface::getSignature方法代碼示例

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


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

示例1: authenticate

 /**
  * Attempts to authenticate a TokenInterface object.
  *
  * @param TokenInterface $token The TokenInterface instance to authenticate
  *
  * @return TokenInterface An authenticated TokenInterface instance, never null
  *
  * @throws AuthenticationException if the authentication fails
  */
 public function authenticate(TokenInterface $token)
 {
     /** @var SignedTokenInterface $token */
     $user = $this->userProvider->loadUserByUsername($token->getUsername());
     $signData = $this->getAuthSignData($token->getRequest());
     $signData[] = $user->{$this->config['secret_getter']}();
     $expectedSignature = hash($this->config['hash_alg'], implode($this->config['data_delimiter'], $signData));
     if ($token->getSignature() == $expectedSignature) {
         $token->setUser($user);
         return $token;
     }
     $this->logger->critical(sprintf('Invalid auth signature. Expect "%s", got "%s"', $expectedSignature, $token->getSignature()), ['signData' => $signData]);
     throw new AuthenticationException("Invalid auth signature " . $token->getSignature());
 }
開發者ID:epustobaev,項目名稱:signed-auth-bundle,代碼行數:23,代碼來源:SignedAuthProvider.php

示例2: authenticate

 /**
  * {@inheritdoc}
  */
 public function authenticate(TokenInterface $token)
 {
     /** @var HmacUserToken $token */
     if ($this->validateServiceLabel($token->getServiceLabel())) {
         $user = $this->userProvider->loadUserByUsername($token->getUsername());
         if ($this->validateSignature($token->getRequest(), $token->getSignature(), $user->getPassword())) {
             $authenticatedToken = new HmacUserToken();
             $authenticatedToken->setUser($user);
             $authenticatedToken->setServiceLabel($token->getServiceLabel());
             $authenticatedToken->setRequest($token->getRequest());
             return $authenticatedToken;
         }
     }
     throw new AuthenticationException('The HMAC authentication failed.');
 }
開發者ID:wridgers,項目名稱:GremoHmacAuthenticationBundle,代碼行數:18,代碼來源:HmacAuthenticationProvider.php

示例3: authenticate

 /**
  * {@inheritdoc}
  */
 public function authenticate(TokenInterface $token)
 {
     /** @var SessionlessToken $token */
     $signature = $token->getSignature($token);
     $user = $this->usersProvider->loadUserByUsername($token->getUsername());
     // Prepares new token, that represents authenticated user.
     $regeneratedToken = new SessionlessToken($token->getUsername(), $token->getExpirationTime(), $token->getIpAddress(), $this->generateSignature($token), $user->getRoles());
     if ($token->getExpirationTime() >= time() && $signature === $regeneratedToken->getSignature()) {
         $regeneratedToken->setAuthenticated(true);
         $regeneratedToken->setUser($user);
         return $regeneratedToken;
     } else {
         $regeneratedToken->setAuthenticated(false);
     }
     throw new AuthenticationException('The Sessionless authentication failed.');
 }
開發者ID:asev,項目名稱:SettingsBundle,代碼行數:19,代碼來源:SessionlessAuthenticationProvider.php

示例4: checkSignature

 /**
  * Check signature
  *
  * @param  TokenInterface  $token
  * @param  ClientInterface $client
  * @return void
  */
 protected function checkSignature(TokenInterface $token, ClientInterface $client)
 {
     if ($client->isSignatureRequired() && !$token->isSigned()) {
         throw new OAuthInvalidRequestException('The request is not signed.');
     }
     if ($client->isSignatureRequired() && $token->isSigned()) {
         if (!$this->signature->verify($token->getSignedUrl(), $client->getSecret(), $token->getSignature())) {
             throw new OAuthInvalidRequestException('The request signature we calculated does not match the signature you provided.');
         }
     }
 }
開發者ID:euskadi31,項目名稱:OAuth2ServerServiceProvider,代碼行數:18,代碼來源:OAuth2AuthenticationProvider.php


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