定制 beastbytes/token 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

beastbytes/token

Composer 安装命令:

composer require beastbytes/token

包简介

Token management library to generate and validate tokens

README 文档

README

BeastBytes Token creates, manages, and validates time limited tokens.

Tokens can be used for a variety of purposes, such as:

  • Account verification
  • Email confirmation
  • Password reset

Requirements

  • PHP 8.1 or higher.

Installation

This package is installed when installing one of the token storage packages:

To install the package directly:

composer require beastbytes/token

or add the following to the 'require' section composer.json:

"beastbytes/token": "^1.0"

Implementation

Token makes no assumptions about the token format or the token storage. Token generation is performed by a TokenFactoryInterface instance (BeastBytes Token UUID4 creates UUID V4 tokens), and storage is performed by a TokenStorageInterface instance (BeastBytes Token PHP and BeastBytes Token Db provide storage implementations for PHP files and databases respectively).

TokenManager

TokenManager provides a simple interface for creating, retrieving, and deleting tokens; abstracting away the storage implementation.

Configuration

To use with Yii's dependency injection container, see the configuration section of the token storage and factory packages.

Token Types

Token types define the purpose of a token and its duration; token types are application specific and must be defined by the application. Token types are defined using an int backed enum that implements TokenTypeInterface; the enum name is the token type and the int value is the token duration in minutes. Each token type must have a unique duration.

Example TokenType enum:

enum TokenType: int implements TokenTypeInterface
{
    use TokenTypeTrait; // implements TokenTypeInterface
    
    case changePassword = 30;
    case confirmEmail = 15;
}

Usage

Take the case of a user account verification process. Once the user has registered their account, the application will raise an event that sends an email to the user; the email will contain a link that will verify that the user created the account.

Event handler

$token = $tokenManager->add(TokenType::verifyAccount, $currentUser->getId());
$email->send($currentUser, $token);

Verification action

On clicking the link in the email, the user is redirected to a page, and so action, that verifies the token; the token is typically a URL parameter.

public function actionVerifyAccount(
    #[RouteArgument('token')] string $tokenValue,
    TokenManager $tokenManager,
): ResponseInterface
{
    $token = $tokenManager->get($tokenValue);    
    
    if ($token instanceof Token) {    
        if ($token->isValid(TokenType::verifyAccount)) {
            $tokenManager->delete($token);
            
            $userId = $token->getUserId();
            // enable the user account
            
            // set success flash message
            return $this->redirect('/login');
        }
    
        // determine why the token is invalid
        $expired = $token->isExpired();
        if ($expired) {
            $tokenManager->delete($token);
            // set token expired flash message
        } else {    
            if (!$token->isType(TokenType::verifyAccount)) {
                // set wrong token type flash message
            }
        }
    } else {
        // set token does not exist flash message
    }
    
    return $this->redirect('/');      
}

统计信息

  • 总下载量: 15
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 0
  • 依赖项目数: 3
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 1
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: BSD-3-Clause
  • 更新时间: 2025-03-21