定制 kozlovsv/yii2-jwt-storage-redis 二次开发

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

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

kozlovsv/yii2-jwt-storage-redis

Composer 安装命令:

composer require kozlovsv/yii2-jwt-storage-redis

包简介

Redis storage for yii2-jwt-auth component

README 文档

README

Redis storage component for kozlovsv/yii2-jwt-auth.

Component provides token storage in redis cache

This component should be used if your application uses Redis cache, and you need functionality that allows you to delete all saved access and refresh tokens for a specific user.

The standard application cache component, which is used in the TokenStorageCache class, converts all keys to an MD5 hash before writing or reading, so there is no way to get all the keys for a specific user. All keys in the cache look like: 402849137963e1945d01315c4f61662f

The TokenStorageRedis component executes the Redis commands directly, and does not use the commands of the standard cache class. Due to this, the keys are not formatted in MD5, but are stored in the cache in their original form.

Fotrat of the key api:token:user_id:token_id.

Example: api:token:1425:9f3898ca702c9c9f4991c63dc7eb0e13.

This formatting allows you to get all the keys for a specific user that are stored in the cache by the search mask. For example, api:token:1425:* will retrieve all stored tokens for user ID 1425.

This makes it possible to remove all of that user's keys from the store.

For example, when you need to log out of all authorized devices for a specific user.

The default key storage component does not allow you to perform this functionality.

Installation

The preferred way to install this extension is through composer.

Either run

php composer.phar require --prefer-dist kozlovsv/yii2-jwt-storage-redis "@dev"

or add

"kozlovsv/yii2-jwt-storage-redis": "@dev"

to the require section of your composer.json file.

Dependencies

Basic usage

Edit jwt component to your configuration file,

'components' => [
    'jwt' => [
        'class' => \kozlovsv\jwtauth\Jwt::class,
        ...
        'tokenStorage' => \kozlovsv\jwtredis\TokenStorageRedis::class, //Set Redis storage class
    ],
],

For examle add method afterSave() to model app\models\User

public function afterSave($insert, $changedAttributes)
    // Purge the user tokens when the password is changed
    if (array_key_exists('password_hash', $changedAttributes)) {
        /** @var Jwt $jwtServ */
        $jwtServ = Yii::$app->get('jwt', false);
        $jwtServ?->tokenStorage->deleteAllForUser($this->id);
    }

    parent::afterSave($insert, $changedAttributes);
}

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2023-04-14