[英]how to store the userid in the session variable for newly created user after registration
[英]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进行添加。
现在,您的新控制器将不会采取注册行为。 这也将使应用程序中的逻辑更加清晰,因为您没有注册用户,而是要创建一个新用户。
稍微扩展一下,当您注册用户时(通过使用Auth \\ RegisteredUsers注册方法),RegisterController将执行以下代码。
$this->guard()->login($user);
return $this->registered($request, $user)
?: redirect($this->redirectPath());
因此,从本质上讲,除非您删除“使用RegisteredUsers”,否则必须遵循我上面提到的方法。 通常不推荐使用RegisterController中的命令。 使用单独的控制器/行为,您可以创建其他逻辑,例如在允许创建用户之前检查用户类型(例如,管理员用户)等。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.