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;",这通常不被推荐。使用单独的控制器/行为允许您创建额外的逻辑,例如在允许创建用户之前检查用户类型(例如管理员用户)等。
在我的应用程序中,我使用了 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;",这通常不被推荐。使用单独的控制器/行为允许您创建额外的逻辑,例如在允许创建用户之前检查用户类型(例如管理员用户)等。