首页 > 技术文章 > 使用laravel/passport获取access_token时出现Object of class DateTime could not be converted to string

trblog 2020-05-29 22:37 原文

场景

在使用passport ~4.0.0包中的/oauth/token路由获取access_token时出现该错误.

原因

追了一下代码后发现,vendor/laravel/passport/src/TokenRepository.php是包里面Token模型使用create的时候created_at,updated_at使用new DateTime时间格式引起的

注:在同php,laravel,passport版本的情况下,另一套laravel环境正常,出现这个时间格式问题应该是这个项目中引入的其他包或配置导致

解决

通过观察器创建监听事件修改created_at,updated_at数据

laravel观察器使用:https://learnku.com/docs/laravel/5.5/eloquent/1332#observers

1:创建观察器

在app/Observers目录下创建观察器Token.php

<?php

namespace App\Observers;

class Token
{
    /**
     * 监听创建事件
     * @param \Laravel\Passport\Token $token
     */
    public function creating(\Laravel\Passport\Token $token)
    {
        $token->created_at = date('Y-m-d H:i:s');
        $token->updated_at = date('Y-m-d H:i:s');
    }
}

2:AppServiceProvider中boot方法中注册服务

public function boot()
{
    Token::observe(\App\Observers\Token::class);
}

3:成功获取access_token:

推荐阅读