destroy () 里面的 $this->user () 最好加上为空判断

public function destroy()
{
    $this->user()->token()->revoke();
    return $this->response->noContent();
}

改成

        if (!empty($this->user())) {
            $this->user()->token()->revoke();
            return $this->response->noContent();
        } else {
            return $this->response->errorUnauthorized('The token is invalid.');
        }
《L02 从零构建论坛系统》
以构建论坛项目 LaraBBS 为线索,展开对 Laravel 框架的全面学习。应用程序架构思路贴近 Laravel 框架的设计哲学。
《G01 Go 实战入门》
从零开始带你一步步开发一个 Go 博客项目,让你在最短的时间内学会使用 Go 进行编码。项目结构很大程度上参考了 Laravel。
讨论数量: 6

@liyu001989 老师,为什么登出接口路由不放在api.auth所在的路由群组,这样就不需要判断登录用户是否为空,在passportProvider里面检测未登录,返回token失效信息

5年前 评论
liyu001989

同意,已修改

5年前 评论

@liyu001989 老师,课程这里还没有修改啊

5年前 评论
liyu001989

@Flourishing 再看看

5年前 评论

@world_hello 好问题

我觉得可以放api.auth的组里,这样就用判断user()是否为空了。

5年前 评论
liyu001989

@world_hello @Aben

api.auth 判断的是 token 是否过期,如果一个 token 过期了,接口应该是依然可以把 token 注销的。

放在 api.auth 里面就是说如果过期了,你必须先刷新一次,可用了之后才能 revoke。

5年前 评论

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!