类型错误:参数 1 传递给 Illuminate\Auth\SessionGuard::login() 在寄存器上重



我的控制器上有这个,但重定向不起作用,它说 类型错误:参数 1 传递给 Illuminate\Auth\SessionGuard::login((,到目前为止我已经尝试过了,但什么都没有

<?php
namespace AppHttpControllersAuth;
use AppEventsNewUserWasRegistered;
use AppHttpControllersController;
use AppModelsUser;
use IlluminateFoundationAuthRegistersUsers;
use Validator;
use Auth;
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 login / registration.
*
* @var string
*/
protected $redirectTo = '/home';
/**
* Create a new controller instance.
*
* @return void
*/
public function __construct()
{
$this->middleware('guest');
}
/**
* Get a validator for an incoming registration request.
*
* @param  array  $data
*
* @return IlluminateContractsValidationValidator
*/
protected function validator(array $data)
{
$rules = [
'email'                => 'required|email|max:255|unique:users',
'password'             => 'required|confirmed|min:6',
'g-recaptcha-response' => 'required|captcha',
'allow_register'       => 'required|accepted',
];
if (app()->environment('local') || app()->environment('testing')) {
unset($rules['g-recaptcha-response']);
}
$data['allow_register'] = config('root.app.allow_register', true);
$messages = [
'allow_register.accepted' => trans('app.allow_register'),
];
return Validator::make($data, $rules, $messages);
}
/**
* Create a new user instance after a valid registration.
*
* @param  array  $data
*
* @return User
*/
protected function create(array $data)
{
$user = User::create([
'username' => md5("{$data['name']}/{$data['email']}"),
'name'     => $data['name'],
'email'    => $data['email'],
'password' => bcrypt($data['password']),
'role_id'     => $data['role'],
]);

event(new NewUserWasRegistered($user));
if($user){
if ($user->role_id == 0) {
Auth::login($user);
return redirect('user/businesses');

}else if($user->role_id == 1){
Auth::login($user);
return 'Working on..';
}
}
// return $user;
} 
}

有人可以帮我吗 我被困住了,我已经尝试了很多东西,但我是编码新手,所以也许你会明白 如果是我要求太多

AppModelsUser必须实现接口/合约IlluminateContractsAuthAuthenticatable

"如果需要将现有用户实例登录到应用程序中,则可以使用用户实例调用login方法。给定的对象必须是IlluminateContractsAuthAuthenticatable协定的实现。当然,Laravel附带的AppUser模型已经实现了这个接口......">

Laravel 5.7 文档 - 身份验证 - 手动验证用户 - 其他身份验证方法

旁注:

该控制器的create方法仅用于获取数据数组并创建新用户并返回该用户实例。没有别的。开箱即用的registration流调用该方法,仅用于创建用户。然后它执行登录和其他所有操作。

最新更新