主頁 > 知識庫 > Laravel的Auth驗證Token驗證使用自定義Redis的例子

Laravel的Auth驗證Token驗證使用自定義Redis的例子

熱門標簽:德陽中江如何申請400開頭電話 沛縣400電話辦理 江蘇電商外呼系統(tǒng)運營商 AI電話機器人OEM貼牌 智能電話機器人好公司門薩維 聊城電話外呼系統(tǒng)公司 青白江地圖標注 銅川電話機器人價格 辦理重慶400電話

背景

項目用戶量逐漸增大,接口調用次數(shù)越來越多,所以決定使用Redis存token,緩解數(shù)據(jù)庫壓力

調研

config/auth.php文件中發(fā)現(xiàn)用戶的驅動使用的是EloquentUserProvider服務提供器,然后查找EloquentUserProvider.php 然后發(fā)現(xiàn)在vendor/laravel/framework/src/Illuminate/Auth文件下存在該文件

?php
 
namespace Illuminate\Auth;
 
use Illuminate\Support\Str;
use Illuminate\Contracts\Auth\UserProvider;
use Illuminate\Contracts\Hashing\Hasher as HasherContract;
use Illuminate\Contracts\Auth\Authenticatable as UserContract;
 
class EloquentUserProvider implements UserProvider
{
 /**
  * The hasher implementation.
  *
  * @var \Illuminate\Contracts\Hashing\Hasher
  */
 protected $hasher;
 
 /**
  * The Eloquent user model.
  *
  * @var string
  */
 protected $model;
 
 /**
  * Create a new database user provider.
  *
  * @param \Illuminate\Contracts\Hashing\Hasher $hasher
  * @param string $model
  * @return void
  */
 public function __construct(HasherContract $hasher, $model)
 {
  $this->model = $model;
  $this->hasher = $hasher;
 }
 
 /**
  * Retrieve a user by their unique identifier.
  *
  * @param mixed $identifier
  * @return \Illuminate\Contracts\Auth\Authenticatable|null
  */
 public function retrieveById($identifier)
 {
  return $this->createModel()->newQuery()->find($identifier);
 }
 ...
  /**
  * Retrieve a user by the given credentials.
  *
  * @param array $credentials
  * @return \Illuminate\Contracts\Auth\Authenticatable|null
  */
 public function retrieveByCredentials(array $credentials)
 {
  if (empty($credentials)) {
   return;
  }
 
  // First we will add each credential element to the query as a where clause.
  // Then we can execute the query and, if we found a user, return it in a
  // Eloquent User "model" that will be utilized by the Guard instances.
  $query = $this->createModel()->newQuery();
 
  foreach ($credentials as $key => $value) {
   if (! Str::contains($key, 'password')) {
    $query->where($key, $value);
   }
  }
 
  return $query->first();
 }
...
}

實現(xiàn)代碼

因為我們是需要在當前的Auth驗證基礎之上添加一層Redis緩存,所以最簡單的辦法繼承EloquentUserProvider類,重寫

retrieveByCredentials方法所以我們新建RedisUserProvider.php文件

?php
namespace App\Providers;
 
use Illuminate\Auth\EloquentUserProvider;
use Cache;
 
class RedisUserProvider extends EloquentUserProvider
{
 
 public function __construct($hasher, $model)
 {
  parent::__construct($hasher, $model);
 }
 /**
  * Retrieve a user by the given credentials.
  *
  * @param array $credentials
  * @return \Illuminate\Contracts\Auth\Authenticatable|null
  */
 public function retrieveByCredentials(array $credentials)
 {
 
  if (!isset($credentials['token'])) {
   return;
  }
 
  $token = $credentials['token'];
  $redis = Cache::getRedis();
  $userId = $redis->get($token);
  
  return $this->retrieveById($userId);
 }
}

然后在AuthServiceProvider.php文件下修改如下代碼

 public function boot(GateContract $gate)
 {
  $this->registerPolicies($gate);
 
  //將redis注入Auth中
  Auth::provider('redis',function($app, $config){
   return new RedisUserProvider($app['hash'], $config['model']);
  });
 }

修改config/auth.php用戶的auth的驅動為redis。

后續(xù)

改完代碼以后發(fā)現(xiàn)無法正常登錄,一直提示用戶或密碼錯誤。。。然后看看了下用戶認證方法是

auth('web')->once($credentials);然后看是在
Illuminate\Auth\SessionGuard文件中用到了RedisUserProvider文件中retrieveByCredentials方法中對用戶進行密碼驗證,

于是修改RedisUserProvider文件

?php
namespace App\Providers;
 
use Illuminate\Auth\EloquentUserProvider;
use Illuminate\Support\Str;
use Illuminate\Contracts\Auth\Authenticatable as UserContract;
use Cache;
 
class RedisUserProvider extends EloquentUserProvider
{
 
 public function __construct($hasher, $model)
 {
  parent::__construct($hasher, $model);
 }
 /**
  * Retrieve a user by the given credentials.
  *
  * @param array $credentials
  * @return \Illuminate\Contracts\Auth\Authenticatable|null
  */
 public function retrieveByCredentials(array $credentials)
 {
 
  if (empty($credentials)) {
   return;
  }
  if(isset($credentials['phone'])  isset($credentials['password'])){
   // First we will add each credential element to the query as a where clause.
   // Then we can execute the query and, if we found a user, return it in a
   // Eloquent User "model" that will be utilized by the Guard instances.
   $query = $this->createModel()->newQuery();
 
   foreach ($credentials as $key => $value) {
    if (! Str::contains($key, 'password')) {
     $query->where($key, $value);
    }
   }
 
   return $query->first();
  }
 
  $token = $credentials['token'];
  $redis = Cache::getRedis();
  $userId = $redis->get($token);
 
  return $this->retrieveById($userId);
 }
}

然后登錄成功啦!皆大歡喜!

以上這篇Laravel的Auth驗證Token驗證使用自定義Redis的例子就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • PHP的Laravel框架結合MySQL與Redis數(shù)據(jù)庫的使用部署
  • Laravel框架使用Redis的方法詳解
  • laravel使用Redis實現(xiàn)網(wǎng)站緩存讀取的方法詳解
  • 關于 Laravel Redis 多個進程同時取隊列問題詳解
  • Redis在Laravel項目中的應用實例詳解
  • Laravel框架實現(xiàn)redis集群的方法分析
  • Laravel如何使用Redis共享Session
  • laravel配置Redis多個庫的實現(xiàn)方法
  • laravel項目利用twemproxy部署redis集群的完整步驟
  • laravel中Redis隊列監(jiān)聽中斷的分析

標簽:山南 鷹潭 赤峰 三亞 南寧 濟寧 烏魯木齊 迪慶

巨人網(wǎng)絡通訊聲明:本文標題《Laravel的Auth驗證Token驗證使用自定義Redis的例子》,本文關鍵詞  Laravel,的,Auth,驗證,Token,;如發(fā)現(xiàn)本文內容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Laravel的Auth驗證Token驗證使用自定義Redis的例子》相關的同類信息!
  • 本頁收集關于Laravel的Auth驗證Token驗證使用自定義Redis的例子的相關信息資訊供網(wǎng)民參考!
  • 企业400电话

    智能AI客服机器人
    15000

    在线订购

    合计11份范本:公司章程+合伙协议+出资协议+合作协议+股权转让协议+增资扩股协议+股权激励+股东会决议+董事会决议

    推薦文章