0

認証モジュールを作成しましたphp artisan make:auth

電子メールの検証後に登録成功を変換しようとしましたが、すべての認証コードがベンダー フォルダー内にあることがわかりました。

以下のルートの場合

 // Authentication Routes...
    Route::get('login', 'Auth\AuthController@showLoginForm');
    Route::post('login', 'Auth\AuthController@login');
    Route::get('logout', 'Auth\AuthController@logout');

    // Registration Routes...
    Route::get('register', 'Auth\AuthController@showRegistrationForm');
    Route::post('register', 'Auth\AuthController@register');

    // Password Reset Routes...
    Route::get('password/reset/{token?}', 'Auth\PasswordController@showResetForm');
    Route::post('password/email', 'Auth\PasswordController@sendResetLinkEmail');
    Route::post('password/reset', 'Auth\PasswordController@reset');

ユーザーを作成し、直接ログインします。しかし、トークン付きのメールを送信してユーザーのメールを確認したいと考えています。

ベンダーで更新するのは良い考えではないことはわかっています. これを処理するように提案してください. または、独自の認証モジュールを作成する必要がありますか?

お時間をいただきありがとうございます、乾杯。

4

1 に答える 1

0

register登録プロセスは、トレイト内のメソッドを通過します。

 /**
 * Handle a registration request for the application.
 *
 * @param  \Illuminate\Http\Request  $request
 * @return \Illuminate\Http\Response
 */
public function register(Request $request)
{
    $validator = $this->validator($request->all());

    if ($validator->fails()) {
        $this->throwValidationException(
            $request, $validator
        );
    }

    Auth::guard($this->getGuard())->login($this->create($request->all()));

    return redirect($this->redirectPath());
}

次に、このメソッドは app ディレクトリの AuthController で 2 つの関数を呼び出します。これは必要に応じて編集できます。

    /**
     * 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|max:255',
            'email' => 'required|email|max:255|unique:users',
            'password' => 'required|confirmed|min:6',
        ]);
    }

    /**
     * Create a new user instance after a valid registration.
     *
     * @param  array  $data
     * @return User
     */
    protected function create(array $data)
    {
        $user = User::create([
            'name' => $data['name'],
            'email' => $data['email'],
            'password' => bcrypt($data['password']),
            //'token' => str_random(10)
        ]);

        //Send email to $user here
        return $user

    }
}

ユーザーがログインできないようにするには、認証ミドルウェアを次のように変更します。

class Authenticate
{
    /**
     * Handle an incoming request.
     *
     * @param  \Illuminate\Http\Request  $request
     * @param  \Closure  $next
     * @param  string|null  $guard
     * @return mixed
     */
    public function handle($request, Closure $next, $guard = null)
    {
        if (Auth::guard($guard)->guest()) {
            if ($request->ajax()) {
                return response('Unauthorized.', 401);
            } else {
                return redirect()->guest('login');
            }
        }

        if (!Auth::user()->validated())
        {
            return redirect()->route('error.message.route');
        }
        return $next($request);
    }
}
于 2016-08-23T08:07:06.187 に答える