Laravel社交名流回调验证(“客户”)->user()为空

Laravel社交名流回调验证(“客户”)->user()为空,laravel,authentication,session,oauth-2.0,laravel-socialite,Laravel,Authentication,Session,Oauth 2.0,Laravel Socialite,拉维尔6号 有两种可能的情况: 已登录用户连接到Google帐户 来宾用户连接到Google帐户将创建一个新用户(如果不存在) 让我们谈谈第一种情况 在my routes/web.php中,没有中间件 Route::get('connect/{provider}', [ConnectController::class, 'connect']) ->name('connect'); Route::get('connect/{provider}/callback', [ConnectC

拉维尔6号

有两种可能的情况:

已登录用户连接到Google帐户 来宾用户连接到Google帐户将创建一个新用户(如果不存在) 让我们谈谈第一种情况

在my routes/web.php中,没有中间件

Route::get('connect/{provider}', [ConnectController::class, 'connect'])
    ->name('connect');
Route::get('connect/{provider}/callback', [ConnectController::class, 'callback'])
    ->name('connect.callback');
在ConnectController.php中

假设用户已登录,并尝试与google连接,但当到达回调时,用户会话消失。我错过了什么


p/S:默认的身份验证驱动程序是admin,无法更改。

经过一天的研究,我发现会话ID与导航到Google之前以及回调请求中的会话ID不同

只需更新config/session.php,并将其设置为lax最初是严格的

class ConnectController extends Controller
{
    public function connect(Request $request, $provider)
    {
        $scopes = config('services.google.scopes');

        // dump(auth('customer')->user()); <------- this 1 has value

        return Socialite::driver($provider)
            ->scopes($scopes)
            ->redirect();
    }

    public function callback(Request $request, $provider)
    {
        $oauthUser = Socialite::driver($provider)->stateless()->user();

        $user = auth('customer')->user();
        debugbar()->log('callback user: ' . ($user->name ?? 'null'));

        // ...

        if (!auth('customer')->check()) {
            debugbar()->log('user not logged in, log in now: ' . $u->name);
            auth('customer')->login($u);
        }
        return redirect()->route('accounts');
    }
log callback user: null
[
    // ...
    'same_site' => 'lax',
]