Laravelでフォローシステムを実装する方法は?
follower_idおよびfollow_idの外部キーを含む、次の名前の移行テーブルを作成し、繰り返し注意を防ぐために一意のインデックスを設定します。 2。2つのbelongstomany関係を定義し、ユーザーモデルのフォロー()とフォロワー()をフォローし、ユーザーがフォローしている人とユーザーをフォローしているユーザーを表します。 3.フォローコントローラーを作成し、フォローメソッドとフォロー解除メソッドを実装し、アタッチとデタッチを介して注意ステータスを管理し、注意を禁止するロジックを追加します。 4. web.phpでルートをフォローおよび解除することを登録します。 5.現在のユーザーが従っているかどうかに基づいて、ブレードテンプレートに注意またはキャンセルフォームを動的に表示します。 6.オプションで、注意状況の判断を簡素化するために、isfollowingメソッドを追加します。 7. APIで使用すると、JSON応答を返すことができます。このソリューションは、Laravelの雄弁な多目的関係の実装に基づいており、明確な構造と拡張が容易です。
Laravelでフォローしているユーザーを実装することは、雄弁な関係とピボットテーブルを使用して簡単です。適切にセットアップするための段階的なガイドを次に示します。

1.フォロー移行を作成します
ユーザー間に次の関係を保存するには、ピボットテーブルが必要です。次の職人コマンドを実行します。
PHP Artisan Make:Migration Create_Follows_Table
生成された移行ファイルで:

スキーマ:: create( 'follows'、function(blueprint $ table){ $ table-> id(); $ table-> foreignid( 'follower_id') - > constrained( 'users') - > ondelete( 'cascade'); $ table-> foreignid( 'follow_id') - > constrained( 'users') - > ondelete( 'cascade'); $ table-> timestamps(); // [複製]を防ぎます $ table-> inited(['follower_id'、 'follow_id']); });
移行を実行します:
PHPの職人が移行します
2。ユーザーモデルで雄弁な関係を設定する
User.php
モデルで、関係を定義します。

// app/models/user.php public function follow() { return $ this-> belongstomany(user :: class、 'follows'、 'follower_id'、 'follow_id'); } パブリック関数フォロワー() { return $ this-> belongstomany(user :: class、 'follows'、 'follow_id'、 'follower_id'); }
これにより、多くの関係があります。
-
following()
このユーザーがフォローしているユーザーを返します。 -
followers()
このユーザーをフォローしているユーザーを返します。
3.フォロー/アンフォローコントローラーメソッドを作成します
[ FollowController
など]を作成して、フォローアクションと解除を処理します。
PHP Artisan Make:Controller FollowController
FollowController.php
:
app \ models \ userを使用してください。 Illuminate \ http \ requestを使用します。 パブリック関数フォロー(ユーザー$ユーザー) { auth() - > user() - > follow() - > attach($ user-> id); return back() - > with( 'success'、 'あなたは今フォローしています'。$ user-> name); } public function unfollow(user $ user) { auth() - > user() - > follow() - > detach($ user-> id); return back() - > with( 'success'、 'your oflowed'。$ user-> name); }
⚠️ユーザーが自分自身に従うことができないことを確認してください(オプションですが推奨されます):
if(auth() - > id()=== $ user-> id){ return back() - > witherrors( 'あなたは自分自身に従うことはできません。'); }
4.ルートを追加します
web.php
:
app \ http \ controllers \ followcontrollerを使用します。 ルート:: post( '/follow/{user}'、[followcontroller :: class、 'follow']) - > name( 'follow'); ルート:: post( '/unfollow/{user}'、[followcontroller :: class、 'unfollow']) - > name( 'unfollow');
5.ブレードビューにフォロー/アンフローボタンを追加します
ユーザープロファイルまたはユーザーリストビュー:
@if(auth() - > user() - > id!== $ user-> id) @if(auth() - > user() - > follof-> contains($ user-> id)) <form action = "{{route( 'unfollow'、$ user)}}" method = "post"> @csrf @method( 'Delete') <button type = "submit"> unfollow </button> </form> @それ以外 <form action = "{{route( 'follow'、$ user)}}" method = "post"> @csrf <button type = "submit">フォロー</button> </form> @endif @endif
注:
@method('DELETE')
を使用する場合は、Restful Routesを好む場合は、それに応じてRoutesと調整の両方として保持します。
6.オプション:ユーザーモデルにヘルパーメソッドを追加します
チェックを簡単にするには:
// user.phpで パブリック関数isfollowing(user $ user) { return $ this-> follow() - > where( 'follow_id'、$ user-> id) - > exists(); } //ブレードの使用:{{auth() - > user() - > isfollowing($ user)? 「oflow」: 'follow'}}
7.オプション:APIルートを使用して(スパに)
APIを構築する場合は、 api
ルートを使用してJSONを返します。
// routes/api.php route :: post( '/follow/{user}'、[api \ followcontroller :: class、 'follow']);
そしてコントローラーで:
return Response() - > json([ 「ステータス」=>「成功」、 「メッセージ」=>「ユーザーが続いた」 ]);
まとめ
これで、次のように動作するシステムがあります。
-
follows
ピボットテーブル - 雄弁な多くの関係
- フォロー/アンフォローのためのコントローラーアクション
- ブレードはそれらと対話するために形成されます
効率的で、スケーラブルで、簡単に拡張できます(たとえば、以下のリクエスト、通知などを追加します)。
基本的に、ピボットテーブルと2つのbelongsToMany
関係だけです。Laravelは簡単にします。
以上がLaravelでフォローシステムを実装する方法は?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undress AI Tool
脱衣画像を無料で

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

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

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

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

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

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

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

Laravelには、リクエスト検証には、コントローラーの検証とフォームリクエストクラスの2つの主な方法があります。 1。コントローラーの検証()メソッドは、単純なシナリオに適しており、ルールを直接渡し、自動的に返信エラー。 2. Formrequestクラスは、複雑または再利用可能なシナリオに適しており、職人を通じてクラスを作成し、ルール()でルールを定義してコードデカップリングと再利用を実現します。 3.ユーザーエクスペリエンスを改善するために、メッセージ()を介してエラープロンプトをカスタマイズできます。 4.属性()を介してフィールドエイリアスを定義して、エラーメッセージをよりフレンドリーにします。 2つの方法には利点と短所があり、プロジェクトのニーズに応じて適切なソリューションを選択する必要があります。

データベースファクトリーは、モデルの偽データを生成するためのLaravelのツールです。フィールドルールを定義することにより、テストまたは開発に必要なデータをすばやく作成します。たとえば、phpartisanmake:Factoryを使用してファクトリーファイルを生成した後、定義()メソッドで名前や電子メールなどのフィールドの生成ロジックを設定し、user :: factory() - > create()を介してレコードを作成します。 1。ユーザー:: Factory(10) - > create()などのバッチ生成データをサポートします。 2。Make()を使用して、未侵入のデータ配列を生成します。 3.フィールド値の一時的な上書きを許可します。 4。自動作成などの協会関係をサポートします

LaravelのEloquentsCopesは、ローカルスコープとグローバルスコープに分割された一般的なクエリロジックをカプセル化するツールです。 1.ローカルスコープは、範囲から始まるメソッドで定義されており、post :: published()など、明示的に呼び出される必要があります。 2.グローバルスコープは、ソフト削除またはマルチテナントシステムによく使用されるすべてのクエリに自動的に適用され、スコープインターフェイスをモデルに実装および登録する必要があります。 3.スコープには、年または月ごとに記事をフィルタリングするなどのパラメーターを装備でき、呼び出し時に対応するパラメーターが渡されます。 4.コードの明確さと再利用性を改善するために使用する場合、命名仕様、チェーンコール、一時的な無効化、および組み合わせの拡張に注意してください。

LaravelbreezeとJetStreamの主な違いは、ポジショニングと機能です。 1.コアポジショニングの観点から、Breezeは、小規模プロジェクトやカスタマイズされたフロントエンドのニーズに適した軽量認定の足場です。 JetStreamは、チーム管理、個人情報設定、APIサポート、2因子検証などの完全なユーザーシステムを提供します。これは、中程度および大規模なアプリケーションに適しています。 2。フロントエンドのテクノロジースタックに関しては、BreezeはデフォルトでBlade Tailwindを使用します。これは、従来のサーバー側のレンダリングを好みます。 JetStreamは、LivewireまたはInertia.js(Vue/Reactと組み合わせて)をサポートしています。これは、最新のSPAアーキテクチャにより適しています。 3。インストールとカスタマイズの観点から、Breezeはよりシンプルで使いやすいです

TheTranSlatorFacadeInLARAVELISUSEDEFORALIZATIONBYFETCHINGTRANSLEATENSTRINGSNANDSWITCHINGLAGUAGESATRUNTIME.TOUSEIT、STORETRANSLATIONSTRINGSINLANGUAGEFILESTRINGSINLANGHELANGDIRECTORY(例えば、ES、FR)、TONRRETRIEVETHEMVIALANG :: get()Orthe ___()Helperfuntiction、
