この記事は、「フォロー」機能をStreamを使用してLaravelアプリケーションに追加することに関する以前のチュートリアルに基づいています。 この部分は、アクティビティ追跡のモデルの構成、ストリームのフィードタイプの探索、フィードの取得、およびビューでそれらをレンダリングすることに焦点を当てています。
重要な概念:
- Stream Laravel's
を使用してを使用し、それに応じてフィードを更新します アクティビティは、表示される前に-
FollowController
FeedManager
を充実させ、生データをビューに優しい形式に変換します。 ストリームはさまざまなフィードタイプ(ニュース、通知)をサポートし、さまざまなアクティビティのカスタムテンプレートを許可します。
- アクティビティデータ構造:
- ストリームは、少なくとも俳優、動詞、オブジェクト、および時間を使用したアクティビティとしてデータを表します。 カスタムフィールドも許可されています
FeedManager
アクティビティとして保存します(俳優、動詞、オブジェクト、時間、およびカスタムデータ)。
オブジェクト:モデルインスタンスへの参照。
俳優:- アクティビティを作成するユーザーへの参照。
- 動詞: アクションを表す文字列(例えば、 'created')。
- 例: モデルの
- を定義します:
activityVerb
Post
class Post extends Model { // ... other code ... /** * Stream: Activity verb for post creation. */ public function activityVerb() { return 'created'; } }。
に設定されたファサードエイリアスからアクセスされます 事前に構成されたフィード:
FeedManager
config/app.php
は、事前に構築されたフィードを提供します:ユーザー、ニュース、および通知。 この例では、主にニュースと通知フィードを使用しています。 他のフィードタイプの詳細については、
。
FeedManagerを使用して機能をフォロー/解除します: FeedManager
は、効率的なフォロー/アンフォローアクションに
フィードの表示:
FollowController
FeedManager
a
// app/Http/Controllers/FollowController.php public function follow(User $user) { if (!Auth::user()->isFollowing($user->id)) { Auth::user()->follows()->create(['target_id' => $user->id]); FeedManager::followUser(Auth::id(), $user->id); return back()->with('success', 'Now following ' . $user->name); } else { return back()->with('error', 'Already following this user.'); } } public function unfollow(User $user) { if (Auth::user()->isFollowing($user->id)) { $follow = Auth::user()->follows()->where('target_id', $user->id)->first(); FeedManager::unfollowUser(Auth::id(), $follow->target_id); $follow->delete(); return back()->with('success', 'Unfollowed ' . $user->name); } else { return back()->with('error', 'Not following this user.'); } }
メソッドは、ビューレンダリングのためにデータ変換を処理します。 このコントローラーアクションにアクセスするためにルートが定義されています
テンプレート:FeedsController
use GetStream\StreamLaravel\Enrich; class FeedsController extends Controller { // ... other code ... public function newsFeed(Request $request) { $feed = FeedManager::getNewsFeeds($request->user()->id)['timeline']; $activities = $feed->getActivities(0, 25)['results']; $activities = $this->enrich()->enrichActivities($activities); return view('feed.newsfeed', ['activities' => $activities]); } private function enrich() { return new Enrich; } // ... other methods ... }
ビューは、個々のアクティビティをレンダリングするために部分的な(enrich
)を使用して、濃縮されたアクティビティを繰り返します。 カスタムアクティビティの部分(たとえば、作成後の
ビューフォルダー内に作成されます。 例部分:
class Post extends Model { // ... other code ... /** * Stream: Activity verb for post creation. */ public function activityVerb() { return 'created'; } }
通知フィード:
Follow
モデルは更新され、通知フィード処理が含まれています:
// app/Http/Controllers/FollowController.php public function follow(User $user) { if (!Auth::user()->isFollowing($user->id)) { Auth::user()->follows()->create(['target_id' => $user->id]); FeedManager::followUser(Auth::id(), $user->id); return back()->with('success', 'Now following ' . $user->name); } else { return back()->with('error', 'Already following this user.'); } } public function unfollow(User $user) { if (Auth::user()->isFollowing($user->id)) { $follow = Auth::user()->follows()->where('target_id', $user->id)->first(); FeedManager::unfollowUser(Auth::id(), $follow->target_id); $follow->delete(); return back()->with('success', 'Unfollowed ' . $user->name); } else { return back()->with('error', 'Not following this user.'); } }
通知フィード用に同様のコントローラーアクション、ルート、およびビュー(notifications.blade.php
)が作成されます。 フォロー通知には、別の部分(notification_follow.blade.php
)が使用されます
結論:
ストリームは、Laravelアプリケーションに堅牢なフィード機能を追加することを簡素化します。 チュートリアルでは、さまざまなアクティビティを追跡し、さまざまなフィードタイプを管理し、ビューで効率的にレンダリングする方法を示しています。 Streamの機能のさらなる調査が奨励されています FAQ(わずかに再フォーマット):FAQSセクションはよく書かれており、役立つ情報を提供します。 重要な変更は必要ありませんが、マイナーなフォーマット調整により、読みやすさが向上する可能性があります。 より良い視覚組織のために、番号付きリストまたは太字の重要な用語を使用することを検討してください。
以上がLaravelとStreamでソーシャルネットワークを構築しますか?簡単!の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

phpssionscanStorestrings、numbers、arrays、andobjects.1.strings:textdatalikeusernames.2.numbers:integersorfloatsforcounters.3.arrays:listslikeshoppingcarts.4.objects:complextructuresthataresialized。

tostartaphpsession、outsession_start()atthescript'sbeginning.1)placeitbe foreanyouttosetthesscookie.2)usesionsionsionsionserdatalikelogintatussorshoppingcarts.3)再生セッションインドストップレベントフィックスアタック

セッション再生とは、新しいセッションIDを生成し、セッション固定攻撃の場合にユーザーが機密操作を実行するときに古いIDを無効にすることを指します。実装の手順には次のものが含まれます。1。感度操作を検出、2。新しいセッションIDを生成する、3。古いセッションIDを破壊し、4。ユーザー側のセッション情報を更新します。

PHPセッションは、アプリケーションのパフォーマンスに大きな影響を与えます。最適化方法には以下が含まれます。1。データベースを使用してセッションデータを保存して応答速度を向上させます。 2。セッションデータの使用を削減し、必要な情報のみを保存します。 3.非ブロッキングセッションプロセッサを使用して、同時実行機能を改善します。 4.セッションの有効期限を調整して、ユーザーエクスペリエンスとサーバーの負担のバランスを取ります。 5.永続的なセッションを使用して、データの読み取り時間と書き込み時間を減らします。

phpsesionsareserver-side、whilecookiesareclient-side.1)Sessionsionsionsoredataontheserver、aremoresecure.2)cookiesstoredataontheclient、cookiestoresecure、andlimitedinsizeisize.sesionsionsionivationivationivationivationivationivationivationivate

phpidentifiesauser'ssessionsingsinssessionCookiesIds.1)whensession_start()iscalled、phpgeneratesauniquesidstoredsored incoookienadphpsessidontheuser'sbrowser.2)thisidallowsphptortorieSessiondatadata fromthata

PHPセッションのセキュリティは、次の測定を通じて達成できます。1。session_regenerate_id()を使用して、ユーザーがログインまたは重要な操作である場合にセッションIDを再生します。 2. HTTPSプロトコルを介して送信セッションIDを暗号化します。 3。Session_Save_Path()を使用して、セッションデータを保存し、権限を正しく設定するためのSecure Directoryを指定します。

phpsessionFilesToredInthededirectoryspecifiedBysession.save_path、通常/tmponunix-likesystemsorc:\ windows \ temponwindows.tocustomizethis:1)uesession_save_path()tosetaCustomdirectory、ensuringit'swritadistradistradistradistradistra


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

VSCode Windows 64 ビットのダウンロード
Microsoft によって発売された無料で強力な IDE エディター

MantisBT
Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。

PhpStorm Mac バージョン
最新(2018.2.1)のプロフェッショナル向けPHP統合開発ツール

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

mPDF
mPDF は、UTF-8 でエンコードされた HTML から PDF ファイルを生成できる PHP ライブラリです。オリジナルの作者である Ian Back は、Web サイトから「オンザフライ」で PDF ファイルを出力し、さまざまな言語を処理するために mPDF を作成しました。 HTML2FPDF などのオリジナルのスクリプトよりも遅く、Unicode フォントを使用すると生成されるファイルが大きくなりますが、CSS スタイルなどをサポートし、多くの機能強化が施されています。 RTL (アラビア語とヘブライ語) や CJK (中国語、日本語、韓国語) を含むほぼすべての言語をサポートします。ネストされたブロックレベル要素 (P、DIV など) をサポートします。

ホットトピック









