Laravel Passport令牌过期方法不起作用

时间:2019-12-23 11:23:01

标签: php laravel access-token laravel-passport

我使用护照对我的API进行身份验证 我运行此命令来安装护照:

php artisan passport:install --force

并使用以下代码生成令牌:

$objToken = $user->createToken('Token');
$strToken = $objToken->accessToken;
$expiration = $objToken->token->expires_at->diffForHumans();

return response()->json([
     token' => $strToken,
     'ExpireTime' => $expiration,
], 200);

我发现我的令牌寿命为一年,我只想将expire_at列设置为1小时 我阅读了官方文档,并将以下代码添加到AuthServiceProvider:

Passport::tokensExpireIn(now()->addDays(15));
Passport::refreshTokensExpireIn(now()->addDays(30));

但是这些代码不起作用,当我登录expire_at时,仍然是一年 请帮助我更改令牌的到期时间。 大量的thakns:)

2 个答案:

答案 0 :(得分:0)

您正在尝试创建个人访问令牌

// Passport::tokensExpireIn(now()->addDays(15));
// Passport::refreshTokensExpireIn(now()->addDays(30));


# Get or set when personal access tokens expire.
Passport::personalAccessTokensExpireIn(now()->addHour(1));

结果:

array:2 [
  "token" => "eyJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiJ9...."
  "ExpireTime" => "59 minutes from now"
]

更新

对于Laravel < v5.7

  

个人访问令牌总是长期存在的。使用tokensExpireInrefreshTokensExpireIn方法时,它们的生命周期不会被修改。

答案 1 :(得分:0)

$objToken = $user->createToken('Token');
$strToken = $objToken->accessToken;
$expiration = $objToken->token;
$expiration->expires_at = Carbon::now()->addWeeks(1);//example 1 week

$expiration->save();

和AuthServiceProvider.php中:

public function boot()
{
    $this->registerPolicies();
    Passport::routes();
    Passport::personalAccessTokensExpireIn(Carbon::now()->addDays(2));//example 2 Days
    //
}