Laravel 5.6 会话在注册后占用新创建的用户

Laravel 5.6 Session takes newly created user after registration

在我的应用程序中,我使用了 php artisan make:auth 命令来提供一些早期的用户登录和注册脚手架。

我注意到,每次我在登录时创建一个新用户,即 UserX,我的用户在向新创建的用户提交注册后发生变化。

示例如下:

以 UserX 身份登录

以 UserZ 身份登录(新注册用户)

=======

我想知道如何才能让当我通过注册创建新用户时,系统保留登录的用户而不是新注册的用户。

下面是注册控制器:

=======

<?php

namespace App\Http\Controllers\Auth;

use App\User;
use App\Http\Controllers\Controller;
use Illuminate\Support\Facades\Hash;
use Illuminate\Support\Facades\Validator;
use Illuminate\Foundation\Auth\RegistersUsers;

class RegisterController extends Controller
{
    /*
    |--------------------------------------------------------------------------
    | Register Controller
    |--------------------------------------------------------------------------
    |
    | This controller handles the registration of new users as well as their
    | validation and creation. By default this controller uses a trait to
    | provide this functionality without requiring any additional code.
    |
    */

    use RegistersUsers;

    /**
     * Where to redirect users after registration.
     *
     * @var string
     */
    protected $redirectTo = '/home';

    /**
     * Create a new controller instance.
     *
     * @return void
     */
    public function __construct()
    {
        $this->middleware('auth');
    }

    /**
     * Get a validator for an incoming registration request.
     *
     * @param  array  $data
     * @return \Illuminate\Contracts\Validation\Validator
     */
    protected function validator(array $data)
    {
        return Validator::make($data, [
            'name' => 'required|string|max:255',
            'email' => 'required|string|email|max:255|unique:users',
            'password' => 'required|string|min:6|confirmed',
        ]);
    }

    /**
     * Create a new user instance after a valid registration.
     *
     * @param  array  $data
     * @return \App\User
     */
    protected function create(array $data)
    {
        return User::create([
            'name' => $data['name'],
            'email' => $data['email'],
            'password' => Hash::make($data['password']),
        ]);
    }
}

如果您需要为用户提供添加新用户的能力,您应该通过 UsersController 来实现。

现在您的新控制器将不会进行注册行为。这也会使您的应用程序中的逻辑更加清晰,因为您不是在注册用户,而是在创建一个新用户。

为了扩展一点,RegisterController 在注册用户时执行以下代码(通过使用 Auth\RegisteredUsers 注册方法)。

        $this->guard()->login($user);

        return $this->registered($request, $user)
                    ?: redirect($this->redirectPath());

所以本质上你必须遵循我上面提到的方法,除非你从 RegisterController 中删除 "use RegisteredUsers;",这通常不被推荐。使用单独的控制器/行为允许您创建额外的逻辑,例如在允许创建用户之前检查用户类型(例如管理员用户)等。