ホームページ  >  記事  >  バックエンド開発  >  デザイン パターン -- オブザーバー パターン_PHP チュートリアル

デザイン パターン -- オブザーバー パターン_PHP チュートリアル

WBOY
WBOYオリジナル
2016-07-14 10:11:28928ブラウズ


[php]
/*
次のシナリオを考えてみましょう:
パスワードを一度間違えた場合は、再度ログインするようリマインダーを送ります
エラーが 2 件あり、確認コードが表示されます
5つ間違えると認証コードが複雑になってしまいます
10回間違えるとアカウントがロックされます

従来の考え:

ユーザー名/パスワードが一致しないと判断された場合{

もし(間違って){
回数+1
}

If (回数 == 1) {
} else if(回数==2){
} その他 {
}....
....

これは明らかに無理があります

}



ユーザー名/パスワードが正しいかどうかを確認します。これはログインカテゴリに属します
。 ログインの成功/失敗、賞罰は賞罰カテゴリに属します。

*/


インターフェースオブザーバー {
関数の更新($obj); }


インターフェイス投稿 {
関数アタッチ($key,$obj); 関数デタッチ($key)

関数 notificationfy(); }

クラス ユーザーが Post {
を実装する パブリック $state = null; パブリック $lastlogin = 0;
保護された $observers = array();
パブリック関数attach($key,$obj) {
$this->observers[$key] = $obj; }

パブリック関数 detach($key) {
unset($this->observers[$key]); }

パブリック関数 notificationfy() {
foreach($this->observers as $obj) {
$obj->update($this); }
}

パブリック関数 Login() {
$this->state = rand(0,1); // 0 が返されると、ユーザー名/パスワードが間違っていることを意味し、1 が返されると、ログインが成功したことを意味します

// 私の話を聞いているすべてのオブジェクトに通知します $this->noticefy();

$this->state を返す
}
}


クラス Log は Observer{
を実装します パブリック関数 update($obj) {
// ログ分析
echo $obj->state?'1 点追加、記録': '1 回間違った、記録して分析'; エコー '
'; }
}

クラス Biz は Observer{
を実装します パブリック関数 update($obj) {
echo (time() - $obj->lastlogin) > 1000?'お久しぶりです':'優良顧客'; }
}



$user = 新しいユーザー(); $log = 新しいログ(); $biz = 新しいビズ();
$user->attach('log',$log); $user->attach('biz',$biz);

//======クライアントのことです=====//

for($i=1;$i $user->ログイン(); エコー '


'; }

/*
次のシナリオを考えてみましょう:
パスワードを一度間違えた場合は、再度ログインするようリマインダーを送ります
エラーが 2 件あり、確認コードが表示されます
5つ間違えると認証コードが複雑になってしまいます
10回間違えるとアカウントがロックされます

一般的なアイデア:

ユーザー名/パスワードが一致しないと判断された場合{

if(間違っている) {
回数+1
}

if(数値==1) {
} else if(回数==2){
} その他 {
}....
....

これは明らかに無理です

}


ユーザー名/パスワードが正しいかどうかを確認します
。 ログインの成功/失敗、賞罰は賞罰カテゴリに属します。

*/


インターフェースオブザーバー {
関数の更新($obj);
}


インターフェイス投稿{
関数attach($key,$obj);
関数デタッチ($key);

関数noticefy();
}

クラス ユーザーがPostを実装する{
パブリック $state = null;
パブリック $lastlogin = 0;

protected $observers = array();

パブリック関数attach($key,$obj) {
$this->observers[$key] = $obj;
}

パブリック関数 detach($key) {
unset($this->observers[$key]);
}

パブリック関数 notificationfy() {
foreach($this->observers as $obj) {
$obj->update($this);
}
}

パブリック関数 Login() {
$this->state = rand(0,1); // 0 が返されると、ユーザー名/パスワードが間違っていることを意味し、1 が返されると、ログインが成功したことを意味します。
// リッスンしているすべてのオブジェクトに通知します
$this->noticefy();

return $this->state;
}
}

クラス Log は Observer{
を実装します パブリック関数の更新($obj) {
// ログ分析
echo $obj->state?'1 点追加、記録':'1 回間違った、記録して分析';
エコー '
';
}
}

クラス Biz は Observer を実装します{

パブリック関数の更新($obj) {
echo (time() - $obj->lastlogin) > 1000?'お久しぶりです':'優良顧客';
; }
}

$user = 新しいユーザー();

$log = 新しいログ();
$biz = 新しいビズ();

$user->attach('log',$log);

$user->attach('biz',$biz);

//======すべてはクライアント次第=====//

for($i=1;$i $user->login();
echo '
';
}


http://www.bkjia.com/PHPjc/477316.htmlwww.bkjia.com本当http://www.bkjia.com/PHPjc/477316.html技術記事 [php] /* 次のシナリオを考えます: パスワードが 1 回間違っている、再ログインのリマインダーが 2 回間違っている、検証コードが 5 回間違っている、検証コードが 10 回間違っている、アカウントをロックする 従来の考え方: ユーザー名とパスワードが一致しないと判断した場合 その後。 ...
声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。