コアポイント
- オブザーバーパターンは、オブジェクトが状態を変更すると、すべての依存オブジェクトが自動的に通知および更新される動作デザインパターンです。
- このモードには、トピック(またはパブリッシャー)とオブザーバー(またはサブスクライバー)が含まれています。被験者は、観察者にステータスの変化を通知し、オブザーバーはそれに応じて行動できます。このモードは、ゆるい結合を促進し、システムをより柔軟にし、変更または拡張しやすくします。 オブザーバークラスは、被験者がその状態の変更を通知するために呼び出す
- 方法を提供します。トピッククラスを定義する主な方法:
update()
、attach()
、detach()
、およびsetState()
は、オブザーバーを管理し、ステータスの変更を通知するために使用されます。notify()
オブザーバーモードは、1つのオブジェクトの変更が他のオブジェクトの変更が必要な状況に適しています。特に変更するオブジェクトの数が不明な場合。関連するオブジェクトをしっかりと結合せずに、関連するオブジェクト間の一貫性を維持するために使用できます。たとえば、ポータルの認証メカニズムをフォーラムソフトウェアにリンクするために使用され、ユーザーが単一のログインで両方にログインできるようにします。
オブザーバーモード
オブザーバーパターン(パブリッシュサブスクライブパターンとも呼ばれます)は、オブジェクト間の1対多くの関係を定義する行動設計パターンであり、オブジェクトが状態を変更すると、すべての従属オブジェクトが自動的に通知され、更新されます。私の場合、このモードを使用して、ポータルの認証メカニズムをフォーラムソフトウェアとリンクしました。ポータルにログインする動作は、ユーザーがフォーラムにログインするように自動的にトリガーされます。自分の状態に興味のある他のオブジェクトと1対多の関係を持つオブジェクトは、トピックまたは出版社と呼ばれます。その依存性オブジェクトは、オブザーバーまたはsubscriberと呼ばれます。被験者の状態が変化するたびに、オブザーバーに通知され、それに応じて行動できます。トピックには、それらのオブザーバーに通知を送信する任意の数の依存的なオブザーバーを持つことができ、そのような通知を受信するためにトピックを購読することができます。
オブザーバーカテゴリオブザーバークラスは、被験者が状態の変更を通知するために呼び出す メソッドを提供します。この例では、特定の方法として メソッドは、観察可能なトピックのインスタンスを受け入れ、トピックに添付します。後で説明します。 テーマカテゴリ
件名クラスは、 、 メソッドは、状態の変更を伝えることができるように、オブザーバーをトピックに購読します。 慎重に追加...一緒に統合します
およびupdate()
メソッドを定義しました。必要に応じて、ここでメソッドを抽象的な方法として定義し、オブザーバーのサブクラスで具体的な実装を提供できます。 update()
<?php
abstract class Observer
{
public function __construct($subject = null) {
if (is_object($subject) && $subject instanceof Subject) {
$subject->attach($this);
}
}
public function update($subject) {
// 查找具有状态名称的观察者方法
if (method_exists($this, $subject->getState())) {
call_user_func_array(array($this, $subject->getState()), array($subject));
}
}
}
__construct()
メソッドは、トピックの現在の状態を取得し、それを使用して、同じ状態名でサブクラス化されたオブザーバーメソッドを呼び出します。したがって、私の特定のケースでは、ポータルの既存の認証クラスを観察可能なトピックとして作成し、具体的なオブザーバーサブクラスを作成して、フォーラムの認証コードに接続する必要があります。私のサブクラスは、トピックの状態を使用してメソッドを実装する必要もあります。 update()
attach()
、detach()
、setState()
の4つの主要な方法を定義する抽象クラスでもあります。便利なため、ここにnotify()
およびgetState()
メソッドも追加しました。 getObservers()
<?php
abstract class Subject
{
protected $observers;
protected $state;
public function __construct() {
$this->observers = array();
$this->state = null;
}
public function attach(Observer $observer) {
$i = array_search($observer, $this->observers);
if ($i === false) {
$this->observers[] = $observer;
}
}
public function detach(Observer $observer) {
if (!empty($this->observers)) {
$i = array_search($observer, $this->observers);
if ($i !== false) {
unset($this->observers[$i]);
}
}
}
public function getState() {
return $this->state;
}
public function setState($state) {
$this->state = $state;
$this->notify();
}
public function notify() {
if (!empty($this->observers)) {
foreach ($this->observers as $observer) {
$observer->update($this);
}
}
}
public function getObservers() {
return $this->observers;
}
}
attach()
メソッドは、トピックのオブザーバーを登録解除して、トピックの状態の変化を観察しなくなるようにします。 detach()
メソッドは、トピックの現在の状態を設定し、setState()
を呼び出して、オブザーバーを更新します。つまり、各オブザーバーに通知を発行します。 notify()
メソッドは、内部リストを繰り返し、各メンバーのnotify()
メソッドを順番に呼び出すことにより、各購読されたオブジェクトを更新します。 update()
およびgetState()
メソッドは、現在のトピックとオブザーバーリストのステータスを返すヘルパー関数にすぎません。 getObservers()
<?php
class Auth extends Subject
{
function login() {
// 执行登录身份验证的现有代码
// ...
// 向任何观察者发出信号,表明用户已登录
$this->setState("login");
}
function logout() {
// 执行用户注销时执行某些操作的现有代码
// 例如销毁会话等...
// 向任何观察者发出信号,表明用户已注销
$this->setState("logout");
}
}
authが観察可能になるようにサブジェクトクラスを拡張し、login()
メソッドでlogout()
への呼び出しを追加しました。オブザーバーをサブクラス化するために、フォーラムのAPIログインおよびログアウト関数を呼び出す責任のあるauth_forumhookクラスを作成しました。 setState()
<?php
class Auth_ForumHook extends Observer
{
function login($subject) {
// 调用论坛的 API 函数以登录用户
// ...
}
function logout($subject) {
// 调用论坛的 API 函数以注销用户
// ...
}
}
その他は、auth_forumhookインスタンスを添付して、オブザーバーに認証の状態の変更を通知します。 <?php
abstract class Observer
{
public function __construct($subject = null) {
if (is_object($subject) && $subject instanceof Subject) {
$subject->attach($this);
}
}
public function update($subject) {
// 查找具有状态名称的观察者方法
if (method_exists($this, $subject->getState())) {
call_user_func_array(array($this, $subject->getState()), array($subject));
}
}
}
これは、抽象的なオブザーバーとサブジェクトクラスを準備する以外に、すべての追加のコーディングニーズです。 AUTHのlogin()
およびlogout()
メソッドによってトリガーされる状態の変更は、auth_forumhookオブザーバーに通知し、フォーラムのユーザーから自動的にログインまたはログアウトします。たとえば、新しいオブザーバーを追加するには、トラッカーにログインして、ユーザーがポータルをログインまたはログアウトしたときに記録するには、特定のオブザーバークラスを提供し、既存の認証オブジェクトのlogin()
およびlogout()
メソッドをさらに変更せずにAUTHトピックに添付します。
概要
別のオブジェクトに依存し、そのオブジェクトの状態が変更されたときに操作を実行する必要がある複数のオブジェクトがある場合、または1つのオブジェクトが誰またはいくつのものであるかを知らずに他のオブジェクトに通知する必要がある場合、オブザーバーパターンは適切で適用可能なデザインパターンです。この記事では、基本的なトピック観察パターンを紹介し、新しい要件を緊密に結合せずに、この動作パターンを使用して既存のクラスの機能を簡単に拡張する方法の具体的な例を提供します。このパターンを使用すると、コードの再利用性を犠牲にすることなく、関連するオブジェクトと従属オブジェクトの間でより高いレベルの一貫性を実現できます。
JPF / ShutterStockの写真(記事の長さのために、後続のFAQSセクションは省略されています。コアコンテンツは再編成され、磨かれています。)以上がオブザーバーパターンを理解するの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

PHPロギングは、Webアプリケーションの監視とデバッグ、および重要なイベント、エラー、ランタイムの動作をキャプチャするために不可欠です。システムのパフォーマンスに関する貴重な洞察を提供し、問題の特定に役立ち、より速いトラブルシューティングをサポートします

Laravelは、直感的なフラッシュメソッドを使用して、一時的なセッションデータの処理を簡素化します。これは、アプリケーション内に簡単なメッセージ、アラート、または通知を表示するのに最適です。 データは、デフォルトで次の要求のためにのみ持続します。 $リクエスト -

PHPクライアントURL(CURL)拡張機能は、開発者にとって強力なツールであり、リモートサーバーやREST APIとのシームレスな対話を可能にします。尊敬されるマルチプロトコルファイル転送ライブラリであるLibcurlを活用することにより、PHP Curlは効率的なexecuを促進します

Laravelは簡潔なHTTP応答シミュレーション構文を提供し、HTTP相互作用テストを簡素化します。このアプローチは、テストシミュレーションをより直感的にしながら、コード冗長性を大幅に削減します。 基本的な実装は、さまざまな応答タイプのショートカットを提供します。 Illuminate \ support \ facades \ httpを使用します。 http :: fake([[ 'google.com' => 'hello world'、 'github.com' => ['foo' => 'bar']、 'forge.laravel.com' =>

顧客の最も差し迫った問題にリアルタイムでインスタントソリューションを提供したいですか? ライブチャットを使用すると、顧客とのリアルタイムな会話を行い、すぐに問題を解決できます。それはあなたがあなたのカスタムにより速いサービスを提供することを可能にします

記事では、PHP 5.3で導入されたPHPの後期静的結合(LSB)について説明し、より柔軟な継承を求める静的メソッドコールのランタイム解像度を可能にします。 LSBの実用的なアプリケーションと潜在的なパフォーマ

この記事では、フレームワークにカスタム機能を追加し、アーキテクチャの理解、拡張ポイントの識別、統合とデバッグのベストプラクティスに焦点を当てています。


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

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

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

ZendStudio 13.5.1 Mac
強力な PHP 統合開発環境

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

DVWA
Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、

ホットトピック



