国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

ホームページ PHPフレームワーク Laravel laravelはログイン登録を?qū)g裝します

laravelはログイン登録を?qū)g裝します

May 20, 2023 pm 09:10 PM

Laravel は、Web アプリケーションをより簡(jiǎn)単に構(gòu)築できる強(qiáng)力な開発環(huán)境を提供する人気の PHP フレームワークです。重要な機(jī)能の 1 つは、Laravel 獨(dú)自の認(rèn)証システムです。これにより、ログインや登録などのユーザー認(rèn)証を迅速に実裝できます。この記事では、Laravelを使用してログイン登録を?qū)g裝する方法を説明します。

デプロイ環(huán)境
認(rèn)証の実裝を開始する前に、Laravel 環(huán)境が構(gòu)成され、データベース接続が構(gòu)成されていることを確認(rèn)する必要があります。 Laravel をまだインストールしていない場(chǎng)合は、公式ドキュメントのインストールガイドを參照してください。 Laravel アプリケーションでは、Artisan コマンド ライン ツールを使用して必要なファイルとディレクトリ構(gòu)造を作成します。コマンドラインから、次のコマンドを使用して新しい Laravel アプリケーションを作成できます:

composer create-project --prefer-dist laravel/laravel blog

作成後、アプリケーションの In に移動(dòng)します。ルート ディレクトリで、次のコマンドを?qū)g行してアプリケーション キーを生成します。

php 職人キー:生成

ルートを登録
Laravel では、ルーティングは URI と対応するコントローラー メソッドを接続するブリッジです。認(rèn)証ルートを登録するには、routes/web.php ファイルを更新する必要があります。このファイルでは、ログイン ルートと登録ルートを含む、アプリケーションのルートを定義します。

まず、POST リクエストを /register に送信するルートを定義し、それを RegisterController の register() メソッドにバインドする必要があります。これにより、ユーザーがユーザー名とパスワードを入力できる登録フォームが表示されます。

Route::post('/register', 'AuthRegisterController@register')->name('register');

次に、送信する POST リクエストを定義する必要があります/login ルートに追加し、LoginController の login() メソッドにバインドします。これにより、ユーザーがログイン名とパスワードを入力できるログイン フォームが表示されます。ユーザーが認(rèn)証に必要な有効な資格情報(bào)を持っていない場(chǎng)合、アプリケーションはログイン フォームにリダイレクトします。

Route::post('/login', 'AuthLoginController@login')->name('login');

最後に、すべての保護(hù)されたルートを定義する必要があります。 Laravel では、認(rèn)証ミドルウェアを使用して、ユーザーが認(rèn)証されていることを確認(rèn)できます。このミドルウェアは、認(rèn)証されていないユーザーを /login ルートに自動(dòng)的にリダイレクトします。

Route::middleware(['auth'])->group(function () {

// your protected routes go here

});

コントローラーの処理
必要なルートが定義されたら、それらをコントローラーで処理する必要があります。 Laravel では、コントローラーは特定の HTTP リクエストを処理するクラスであり、コントローラー內(nèi)のメソッドは HTTP レスポンスを返します。アプリケーションでは、登録リクエストとログインリクエストを処理するために 2 つのコントローラーを作成する必要があります。

app/Http/Controllers/Auth ディレクトリに、LoginController.php と RegisterController.php の 2 つのファイルを作成します。これら 2 つのファイルは、Laravel に付屬するコントローラー クラスです。これらのコントローラーでは、Laravel のデフォルトのメソッドをオーバーライドして、ログインおよび登録リクエストのカスタム機(jī)能を提供する必要があります。

ログイン コントローラー
まず、LoginController.php コントローラーを見てみましょう。このコントローラーには、showLoginForm() と login() という 2 つのメソッドが含まれています。

showLoginForm() メソッドは、ログイン フォーム ビュー (resources/views/auth/login.blade.php) を返します。このビューには、ユーザーがログイン名とパスワードを入力できるフォームが含まれています。このメソッドはLaravelによって提供されています。

public function showLoginForm()
{

return view('auth.login');

}

login() メソッドは、ログイン ロジックが実際に実裝される場(chǎng)所です。このメソッドは IlluminateHttpRequest インスタンスを受け取り、インスタンスの validate() メソッドを使用してユーザー入力を検証します。フォームの検証が成功すると、Laravel は指定されたログイン名とパスワードでユーザーを自動(dòng)的に検索し、アプリケーションにログインします。

public function login(Request $request)
{

$request->validate([
    'email' => 'required|string|email',
    'password' => 'required|string',
    'remember' => 'boolean'
]);

$credentials = $request->only('email', 'password');

if (Auth::attempt($credentials, $request->remember)) {
    return redirect()->intended('dashboard');
}

return redirect()->back()->withInput($request->only('email', 'remember'));

}

attempt() メソッドは、パスワードが正しいかどうかを自動(dòng)的にチェックすることに注意してください。指定された資格情報(bào)。パスワードが間違っている場(chǎng)合は false が返されます。

ユーザーが正常に認(rèn)証され、以前にリクエストした URL (通常は認(rèn)証ミドルウェアによってブロックされた URL) が保存されている場(chǎng)合は、Laravel ヘルパー関數(shù) Indeed() を使用してユーザーをその URL にリダイレクトできます。 URL が保存されていない場(chǎng)合は、フロントエンド ダッシュボード (/dashboard) にリダイレクトします。

Register Controller

次に、RegisterController.php コントローラーを見てみましょう。 Laravel のデフォルトのメソッドに加えて、 register() メソッドも実裝する必要があります。

register() メソッドは、login() メソッドと非常によく似ています。 IlluminateHttpRequest インスタンスを受け取り、インスタンスの validate() メソッドを使用してユーザー入力を検証します。フォームの検証が成功すると、Laravel は新しいユーザーを作成し、データベースに保存します。その後、Laravel のデフォルトの動(dòng)作を使用して、ユーザーをアプリケーションにログインさせることができます。


public function register(Request $request)

{

$request->validate([
    'name' => 'required|string|max:255',
    'email' => 'required|string|email|max:255|unique:users',
    'password' => 'required|string|min:6|confirmed',
]);

$user = User::create([
    'name' => $request->name,
    'email' => $request->email,
    'password' => Hash::make($request->password),
]);

Auth::login($user);

return redirect()->intended('dashboard');

}

登録コントローラーでは、ハッシュ補(bǔ)助関數(shù)を使用してパスワードを暗號(hào)化できます。パスワードの検証が成功した場(chǎng)合は、新しいユーザーを作成し、アプリケーションにログインします。


ビュー レイヤー

必要なルートとコントローラーを定義したので、認(rèn)証ビューを作成する必要があります。 ###

在 resources/views/auth 目錄中,我們可以創(chuàng)建 login.blade.php 和 register.blade.php 兩個(gè)視圖文件。這些視圖包含登錄和注冊(cè)表單,使用了一些 Laravel 幫助程序,可以處理表單驗(yàn)證并顯示錯(cuò)誤消息。

登錄視圖
在 login.blade.php 文件中,我們可以使用 Laravel 的 Form 輔助函數(shù)創(chuàng)建登錄表單。這個(gè)函數(shù)會(huì)自動(dòng)為表單添加 CSRF 令牌,并為輸入字段編寫 HTML 標(biāo)記。

@csrf

<div class="form-group row">
    <label for="email" class="col-sm-4 col-form-label text-md-right">{{ __('Email Address') }}</label>

    <div class="col-md-6">
        <input id="email" type="email" class="form-control{{ $errors->has('email') ? ' is-invalid' : '' }}" name="email" value="{{ old('email') }}" required autofocus>

        @if ($errors->has('email'))
            <span class="invalid-feedback" role="alert">
                <strong>{{ $errors->first('email') }}</strong>
            </span>
        @endif
    </div>
</div>

<div class="form-group row">
    <label for="password" class="col-md-4 col-form-label text-md-right">{{ __('Password') }}</label>

    <div class="col-md-6">
        <input id="password" type="password" class="form-control{{ $errors->has('password') ? ' is-invalid' : '' }}" name="password" required>

        @if ($errors->has('password'))
            <span class="invalid-feedback" role="alert">
                <strong>{{ $errors->first('password') }}</strong>
            </span>
        @endif
    </div>
</div>

<div class="form-group row">
    <div class="col-md-6 offset-md-4">
        <div class="form-check">
            <input class="form-check-input" type="checkbox" name="remember" id="remember" {{ old('remember') ? 'checked' : '' }}>

            <label class="form-check-label" for="remember">
                {{ __('Remember Me') }}
            </label>
        </div>
    </div>
</div>

<div class="form-group row mb-0">
    <div class="col-md-8 offset-md-4">
        <button type="submit" class="btn btn-primary">
            {{ __('Login') }}
        </button>

        @if (Route::has('password.request'))
            <a class="btn btn-link" href="{{ route('password.request') }}">
                {{ __('Forgot Your Password?') }}
            </a>
        @endif
    </div>
</div>

注意,我們使用了 Blade 模板引擎的 @csrf 和 @if 語(yǔ)句來(lái)生成必要的 CSRF 令牌并顯示驗(yàn)證錯(cuò)誤。

注冊(cè)視圖
在 register.blade.php 文件中,我們可以使用 Laravel 的 Form 幫助器創(chuàng)建注冊(cè)表單。這個(gè)函數(shù)自動(dòng)為表單添加 CSRF 令牌,并為輸入字段編寫 HTML 標(biāo)記。

@csrf

<div class="form-group row">
    <label for="name" class="col-md-4 col-form-label text-md-right">{{ __('Name') }}</label>

    <div class="col-md-6">
        <input id="name" type="text" class="form-control{{ $errors->has('name') ? ' is-invalid' : '' }}" name="name" value="{{ old('name') }}" required autofocus>

        @if ($errors->has('name'))
            <span class="invalid-feedback" role="alert">
                <strong>{{ $errors->first('name') }}</strong>
            </span>
        @endif
    </div>
</div>

<div class="form-group row">
    <label for="email" class="col-md-4 col-form-label text-md-right">{{ __('E-Mail Address') }}</label>

    <div class="col-md-6">
        <input id="email" type="email" class="form-control{{ $errors->has('email') ? ' is-invalid' : '' }}" name="email" value="{{ old('email') }}" required>

        @if ($errors->has('email'))
            <span class="invalid-feedback" role="alert">
                <strong>{{ $errors->first('email') }}</strong>
            </span>
        @endif
    </div>
</div>

<div class="form-group row">
    <label for="password" class="col-md-4 col-form-label text-md-right">{{ __('Password') }}</label>

    <div class="col-md-6">
        <input id="password" type="password" class="form-control{{ $errors->has('password') ? ' is-invalid' : '' }}" name="password" required>

        @if ($errors->has('password'))
            <span class="invalid-feedback" role="alert">
                <strong>{{ $errors->first('password') }}</strong>
            </span>
        @endif
    </div>
</div>

<div class="form-group row">
    <label for="password-confirm" class="col-md-4 col-form-label text-md-right">{{ __('Confirm Password') }}</label>

    <div class="col-md-6">
        <input id="password-confirm" type="password" class="form-control" name="password_confirmation" required>
    </div>
</div>

<div class="form-group row mb-0">
    <div class="col-md-6 offset-md-4">
        <button type="submit" class="btn btn-primary">
            {{ __('Register') }}
        </button>
    </div>
</div>

注意,我們使用了 Blade 模板引擎的 @csrf 和 @if 語(yǔ)句來(lái)生成必要的 CSRF 令牌并顯示驗(yàn)證錯(cuò)誤消息。

結(jié)論
通過 Laravel 可以快速、方便、安全地實(shí)現(xiàn) Web 應(yīng)用程序的登錄和注冊(cè)身份驗(yàn)證功能,從而保護(hù)您的應(yīng)用程序免受未授權(quán)的訪問。在本文中,我們介紹了 Laravel 的身份驗(yàn)證系統(tǒng)并實(shí)現(xiàn)了注冊(cè)和登錄?,F(xiàn)在,您可以使用這些基礎(chǔ)知識(shí)構(gòu)建更完整的用戶身份驗(yàn)證系統(tǒng),或?qū)⑵浼傻侥默F(xiàn)有應(yīng)用程序中。

以上がlaravelはログイン登録を?qū)g裝しますの詳細(xì)內(nèi)容です。詳細(xì)については、PHP 中國(guó)語(yǔ) Web サイトの他の関連記事を參照してください。

このウェブサイトの聲明
この記事の內(nèi)容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰屬します。このサイトは、それに相當(dāng)する法的責(zé)任を負(fù)いません。盜作または侵害の疑いのあるコンテンツを見つけた場(chǎng)合は、admin@php.cn までご連絡(luò)ください。

ホットAIツール

Undress AI Tool

Undress AI Tool

脫衣畫像を無(wú)料で

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード寫真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

寫真から衣服を削除するオンライン AI ツール。

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無(wú)料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡(jiǎn)単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無(wú)料のコードエディター

SublimeText3 中國(guó)語(yǔ)版

SublimeText3 中國(guó)語(yǔ)版

中國(guó)語(yǔ)版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強(qiáng)力な PHP 統(tǒng)合開発環(huán)境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Laravelアプリケーションのパフォーマンスを最適化するための戦略 Laravelアプリケーションのパフォーマンスを最適化するための戦略 Jul 09, 2025 am 03:00 AM

Laravel Performanceの最適化により、4つのコア方向を通じてアプリケーション効率を向上させることができます。 1.キャッシュメカニズムを使用して重複クエリを削減し、データベースアクセス頻度を減らすためにキャッシュ:: remember()およびその他の方法を介してデータをまったく変更します。 2.モデルからクエリステートメントまでデータベースを最適化し、n 1クエリを回避し、フィールドクエリの指定、インデックスの追加、ページングの処理と読み取りと書き込みの分離を削減し、ボトルネックを削減します。 3.電子メールの送信やキューの非同期処理へのエクスポートなどの時(shí)間のかかる操作を使用し、監(jiān)督者を使用して労働者を管理し、再試行メカニズムを設(shè)定します。 4.複雑なロジックと不必要な初期化コードを回避するために、ミドルウェアとサービスプロバイダーを合理的に使用し、スタートアップ効率を改善するためにサービスの負(fù)荷を遅らせます。

API認(rèn)証のために、Laravel SanctumとPassportを選択します API認(rèn)証のために、Laravel SanctumとPassportを選択します Jul 14, 2025 am 02:35 AM

Laravelsanctumは、SPAやモバイルアプリケーションなどのシンプルで軽量のAPI認(rèn)定に適していますが、パスポートは、完全なOAUTH2機(jī)能が必要なシナリオに適しています。 1。Sanctumは、ファーストパーティクライアントに適したトークンベースの認(rèn)証を提供します。 2。パスポートは、サードパーティの開発者がアクセスするのに適した、承認(rèn)コードやクライアント資格情報(bào)などの複雑なプロセスをサポートしています。 3. Sanctumの設(shè)置と構(gòu)成はより簡(jiǎn)単で、メンテナンスコストは低いです。 4.パスポート関數(shù)は包括的ですが、構(gòu)成は複雑で、微細(xì)な許可制御が必要なプラットフォームに適しています。選択するときは、プロジェクトの要件に基づいてOAUTH2機(jī)能が必要かどうかを判斷する必要があります。

Laravelでテストするためのデータベース?fàn)顟B(tài)の管理 Laravelでテストするためのデータベース?fàn)顟B(tài)の管理 Jul 13, 2025 am 03:08 AM

Laravelテストでデータベース?fàn)顟B(tài)を管理する方法には、RefreshDatabaseの使用、データの選択的シード、トランザクションの慎重な使用、および必要に応じて手動(dòng)クリーニングが含まれます。 1. refressdatabasetraitを使用して、データベース構(gòu)造を自動(dòng)的に移行して、各テストがクリーンなデータベースに基づいていることを確認(rèn)します。 2。特定の種子を使用して必要なデータを埋め、モデル工場(chǎng)と組み合わせて動(dòng)的データを生成します。 3. DataBasTransactionStraitを使用してテストの変更をロールバックしますが、その制限に注意してください。 4.自動(dòng)的にクリーニングできない場(chǎng)合、テーブルを手動(dòng)で切り捨てるか、データベースを再編成します。これらの方法は、テストと環(huán)境の種類に従って柔軟に選択され、テストの信頼性と効率を確保します。

Laravelでデータベーストランザクションを?qū)g裝していますか? Laravelでデータベーストランザクションを?qū)g裝していますか? Jul 08, 2025 am 01:02 AM

Laravelは、組み込みサポートを備えたデータベーストランザクション処理を簡(jiǎn)素化します。 1。DB:: Transaction()メソッドを使用して、自動(dòng)的に操作を自動(dòng)的にコミットまたはロールバックして、データの整合性を確保します。 2。ネストされたトランザクションをサポートし、セーブポイントを通じてそれらを?qū)g裝しますが、通常、複雑さを避けるために単一のトランザクションラッパーを使用することをお?jiǎng)幛幛筏蓼埂?3. begintransaction()、compid()、rollback()などの手動(dòng)制御方法を提供します。これは、より柔軟な処理を必要とするシナリオに適しています。 4.ベストプラクティスには、トランザクションを短く保つことが含まれ、必要に応じてそれらを使用する、障害のテスト、ロールバック情報(bào)の記録が含まれます。トランザクション管理方法を合理的に選択すると、アプリケーションの信頼性とパフォーマンスを向上させることができます。

LaravelでのHTTPリクエストと応答の処理。 LaravelでのHTTPリクエストと応答の処理。 Jul 16, 2025 am 03:21 AM

LaravelでHTTP要求と応答を処理するコアは、リクエストデータの取得、応答リターン、ファイルアップロードをマスターすることです。 1.リクエストデータを受信する場(chǎng)合、タイププロンプトを介してリクエストインスタンスを挿入し、入力()またはマジックメソッドを使用してフィールドを取得し、検証のために検証()またはフォームリクエストクラスを組み合わせることができます。 2。返信応答は、文字列、ビュー、JSON、ステータスコードとヘッダーを使用した応答をサポートし、操作をリダイレクトします。 3.ファイルのアップロードを処理するときは、ファイル()メソッドとstore()を使用してファイルを保存する必要があります。アップロードする前に、ファイルの種類とサイズを確認(rèn)する必要があり、ストレージパスをデータベースに保存できます。

Laravelの名前付きルートのURLを生成します。 Laravelの名前付きルートのURLを生成します。 Jul 16, 2025 am 02:50 AM

Laravelで名前付きルートを生成する最も一般的な方法は、ルート名とハンドルパラメーターバインディングに基づいてパスを自動(dòng)的に一致させるルート()ヘルパー関數(shù)を使用することです。 1。ルート( 'user.profile'、['id' => 1])などのコントローラーまたはビューのルート名とパラメーターを渡す); 2。複數(shù)のパラメーターの場(chǎng)合、配列を渡すだけで、順序はルート( 'user.post.show'、['id' => 1、 'postid' => 10]などの一致に影響しません。 3.リンクは、表示情報(bào)の表示など、ブレードテンプレートに直接埋め込むことができます。 4.オプションのパラメーターが提供されていない場(chǎng)合、ルート( 'user.post'、routeなど)は表示されません。

Laravelの構(gòu)成キャッシュとは何ですか? Laravelの構(gòu)成キャッシュとは何ですか? Jul 27, 2025 am 03:54 AM

Laravelの構(gòu)成キャッシュは、すべての構(gòu)成ファイルを単一のキャッシュファイルにマージすることにより、パフォーマンスを向上させます。生産環(huán)境で構(gòu)成キャッシュを有効にすると、各リクエストでI/O操作を削減し、ファイルの解析を行うと、構(gòu)成の読み込みが高速化されます。 1.アプリケーションが展開され、構(gòu)成が安定しており、頻繁な変更は必要ありません。 2。構(gòu)成を有効にして変更した後、phpartisanconfigを再実行する必要があります:キャッシュを有効にします。 3.構(gòu)成ファイルのランタイム條件に依存する動(dòng)的ロジックまたはクロージャーを使用しないでください。 4.トラブルシューティングの問題の場(chǎng)合、まずキャッシュをクリアし、.ENV変數(shù)を確認(rèn)して、再キャッシュする必要があります。

Laravelでキューの優(yōu)先順位の構(gòu)成と使用 Laravelでキューの優(yōu)先順位の構(gòu)成と使用 Jul 08, 2025 am 01:43 AM

Laravelのキューの優(yōu)先順位は、スタートアップシーケンスを通じて制御されます。特定の手順は次のとおりです。1。構(gòu)成ファイルに複數(shù)のキューを定義します。 2. phpartisanqueue:work - queue = high、defaultなど、労働者を起動(dòng)するときにキューの優(yōu)先順位を指定します。 3. onqueue()メソッドを使用して、タスクを配布するときにキュー名を指定します。 4. laravelhorizo??nおよびその他のツールを使用して、キューのパフォーマンスを監(jiān)視および管理します。これにより、コードの保守性とシステムの安定性を維持しながら、優(yōu)先度の高いタスクが最初に処理されることが保証されます。

See all articles