5.4 中 Auth::guard ('API')->user () 和 Auth::user () 有什么区别?

Auth::user () 不是可以获取当前登录用户的信息,为什么有时候返回空,非得写成 Auth::guard ('api')->user ()

《L03 构架 API 服务器》
你将学到如 RESTFul 设计风格、PostMan 的使用、OAuth 流程,JWT 概念及使用 和 API 开发相关的进阶知识。
《L02 从零构建论坛系统》
以构建论坛项目 LaraBBS 为线索,展开对 Laravel 框架的全面学习。应用程序架构思路贴近 Laravel 框架的设计哲学。
讨论数量: 1

注意看源码和 config/auth.php 配置文件。

'defaults' => [
        'guard' => 'web',
        'passwords' => 'users',
    ],

'guards' => [
        'web' => [
            'driver' => 'session',
            'provider' => 'users',
        ],

        'admin' => [
            'driver' => 'session',
            'provider' => 'admins',
        ],

        'api' => [
            'driver' => 'passport',
            'provider' => 'users',
        ],
    ],

Auth::user () 源码下是没有指定 guard,所以会使用默认的 guard,如果你是默认普通的 web 请求,那么肯定是能够拿到当前用户的。

而 Auth::guard ('API')->user () 能拿到用户,说明你本身是 API 的请求,所以 Auth::user () 是拿不到 API 请求下的用户的,除非你指定默认 guard 为 api

7年前 评论

注意看源码和 config/auth.php 配置文件。

'defaults' => [
        'guard' => 'web',
        'passwords' => 'users',
    ],

'guards' => [
        'web' => [
            'driver' => 'session',
            'provider' => 'users',
        ],

        'admin' => [
            'driver' => 'session',
            'provider' => 'admins',
        ],

        'api' => [
            'driver' => 'passport',
            'provider' => 'users',
        ],
    ],

Auth::user () 源码下是没有指定 guard,所以会使用默认的 guard,如果你是默认普通的 web 请求,那么肯定是能够拿到当前用户的。

而 Auth::guard ('API')->user () 能拿到用户,说明你本身是 API 的请求,所以 Auth::user () 是拿不到 API 请求下的用户的,除非你指定默认 guard 为 api

7年前 评论