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

8年前 评论

注意看源码和 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

8年前 评论

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