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

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

《L05 电商实战》
从零开发一个电商项目,功能包括电商后台、商品 & SKU 管理、购物车、订单管理、支付宝支付、微信支付、订单退款流程、优惠券等
《L03 构架 API 服务器》
你将学到如 RESTFul 设计风格、PostMan 的使用、OAuth 流程,JWT 概念及使用 和 API 开发相关的进阶知识。
讨论数量: 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年前 评论