场景
在使用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:
使用laravel/passport获取access_token时出现Object of class DateTime could not be converted to string