Laravel: Как зарегистрировать пользователя через логин? - PullRequest
0 голосов
/ 07 мая 2018

Я использую стандартный метод login/registration Auth Controllers. Цель состоит в том, чтобы зарегистрировать нового пользователя, когда пользователь входит в систему, если такого пользователя нет, или просто авторизоваться, если он есть. На мой взгляд, это должно быть просто переназначить пару методов. Для начала я поменял

AuthenticatesUsers.php

    public function login(Request $request)
    {
        $this->validateLogin($request);

        // If the class is using the ThrottlesLogins trait, we can automatically throttle
        // the login attempts for this application. We'll key this by the username and
        // the IP address of the client making these requests into this application.
        if ($this->hasTooManyLoginAttempts($request)) {
            $this->fireLockoutEvent($request);

            return $this->sendLockoutResponse($request);
        }

        if ($this->attemptLogin($request)) {
            return $this->sendLoginResponse($request);
        }


        $this->incrementLoginAttempts($request);

        //return $this->sendFailedLoginResponse($request);
    }

With commenting the last line it will not say that there is no such user, and I believe right there I should put register method, but I can't find the right way to include it. I suggest that I should use `RegisterUsers.php`

AuthenticatesUsers.php - это контроллер, который выполняет логику входа в систему. Мы смотрим на публичную функцию входа в систему

    AuthenticatesUsers.php
    <?php

namespace Illuminate\Foundation\Auth;

use Illuminate\Http\Request;
use Illuminate\Support\Facades\Auth;
use Illuminate\Validation\ValidationException;
use Illuminate\Support\Facades\Validator;
use Illuminate\Auth\Events\Registered;
use Illuminate\Foundation\Auth\RegistersUsers;

trait AuthenticatesUsers
{
    use RedirectsUsers, ThrottlesLogins, RegistersUsers;


    public function showLoginForm()
    {
        return view('auth.login');
    }

    public function login(Request $request)
    {
        $this->validateLogin($request);


        if ($this->hasTooManyLoginAttempts($request)) {
            $this->fireLockoutEvent($request);

            return $this->sendLockoutResponse($request);
        }

        if ($this->attemptLogin($request)) {
            return $this->sendLoginResponse($request);
        }


        $this->incrementLoginAttempts($request);

        //return $this->sendFailedLoginResponse($request);
        $this->register($request);
    }

    public function register(Request $request)
    {
        $this->validator($request->all())->validate();

        event(new Registered($user = $this->create($request->all())));

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

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

    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',
        ]);
    }

    protected function validateLogin(Request $request)
    {
        $this->validate($request, [
            $this->username() => 'required|string',
            'password' => 'required|string',
        ]);
    }

    protected function attemptLogin(Request $request)
    {
        return $this->guard()->attempt(
            $this->credentials($request), $request->filled('remember')
        );
    }

    protected function credentials(Request $request)
    {
        return $request->only($this->username(), 'password');
    }

    protected function sendLoginResponse(Request $request)
    {
        $request->session()->regenerate();

        $this->clearLoginAttempts($request);

        return $this->authenticated($request, $this->guard()->user())
                ?: redirect()->intended($this->redirectPath());
    }

    protected function authenticated(Request $request, $user)
    {
        //
    }

    protected function sendFailedLoginResponse(Request $request)
    {
        throw ValidationException::withMessages([
            $this->username() => [trans('auth.failed')],
        ]);
    }

    public function username()
    {
        return 'email';
    }

    public function logout(Request $request)
    {
        $this->guard()->logout();

        $request->session()->invalidate();

        return redirect('/');
    }

    protected function guard()
    {
        return Auth::guard();
    }
}

Ответы [ 3 ]

0 голосов
/ 07 мая 2018

Реализуйте этот метод в вашем LoginController

protected function attemptLogin(Request $request)
{
    // here you can check if user is present or just create.
    return $this->guard()->attempt(
        $this->credentials($request), $request->filled('remember')
    );
}
0 голосов
/ 08 мая 2018

Все, что мне нужно было сделать, это обратиться к модели пользователя, не нужно указывать какие-либо методы. вот как должна выглядеть функция в AuthenticatesUsers.php:

public function login(Request $request)
{
    $this->validateLogin($request);

    // If the class is using the ThrottlesLogins trait, we can automatically throttle
    // the login attempts for this application. We'll key this by the username and
    // the IP address of the client making these requests into this application.
    if ($this->hasTooManyLoginAttempts($request)) {
        $this->fireLockoutEvent($request);

        return $this->sendLockoutResponse($request);
    }

    if ($this->attemptLogin($request)) {
        return $this->sendLoginResponse($request);
    }

    // If the login attempt was unsuccessful we will increment the number of attempts
    // to login and redirect the user back to the login form. Of course, when this
    // user surpasses their maximum number of attempts they will get locked out.
    $this->incrementLoginAttempts($request);

    //return $this->sendFailedLoginResponse($request);
    $user = User::where('email', '=', $_POST['email'])->first();
    if ($user === null) {
        return User::create([
            'name' => $_POST['email'],
            'email' => $_POST['email'],
            'password' => Hash::make($_POST['password']),
        ]);
    }
    else
        echo 'Wrong password';
}
0 голосов
/ 07 мая 2018

просто переопределите метод register из RegisterUsers.php в ваш LoginController.

public function register(Request $request)
{
    $this->validator($request->all())->validate();

    event(new Registered($user = $this->create($request->all())));

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

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

Также добавьте защищенную функцию validator из RegisterController и отредактируйте в соответствии с вашими полями.

Также не забудьте отредактировать массив User model fillable и относительный файл миграции для создания таблицы users. Установите Nullable() для полей, которые вы не собираетесь вводить во время Login.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...