91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

什么是php中責任鏈模式

發布時間:2020-08-10 09:34:08 來源:億速云 閱讀:117 作者:Leah 欄目:編程語言

這期內容當中小編將會給大家帶來有關什么是php中責任鏈模式,文章內容豐富且以專業的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

責任鏈模式屬于行為型設計模式,將請求沿著處理者鏈進行發送, 收到請求后, 每個處理者均可對請求進行處理, 或將請求傳遞給鏈上的下個處理者。鏈上的每個處理者都有自己的處理職責,所以叫責任鏈模式。

場景

假如目前有一個系統,現在我們希望對系統的訪問進行限制。首先是登錄驗證,該系統的所有請求都需要在登錄狀態下才能獲取。

過了一段時間后,老板覺得應該加入防爬蟲程序。老板的任務最大,你立即將防爬蟲的功能加入到原本的校驗代碼中。目前就登錄校驗以及防爬蟲校驗,還不是很復雜。但又過了幾天,老板又覺得應該加入限流的校驗……。過了幾天,老板……。

關于校驗的代碼塊已經變的臃腫不堪,代碼變得難以閱讀、難以維護。這個時候,如果我們用責任鏈模式來重寫校驗的功能系統,那么就會像下面一樣:

什么是php中責任鏈模式

通過責任鏈模式,多個處理者都有機會處理請求。將原本的模塊分成多個處理者來處理,符合單一職責原則,代碼的可讀性也大大提高。另外,非常容易擴展,需要新的校驗功能時,只要添加新的處理者即可,符合開閉原則。

責任鏈模式結構

下面我們來完成一個責任鏈模式結構的代碼。每個處理者的功能非常簡單,就是處理請求,然后設置下一個請求處理者。下面是示例代碼:

abstract class AHandler
{
    protected $nextHandler = null;
    
    public function setNext (AHandler $handler)
    {
        $this->nextHandler = $handler;
    }
    
    abstract public function handler ();
}
class Handler1 extends AHandler
{
    public function handler()
    {
        $handled = false;
        
        // 處理請求
        echo 'Handler1接受到了請求' . PHP_EOL;
        
        if (!$handled && $this->nextHandler) {
            $this->nextHandler->handler();
        }
    }
}
class Handler2 extends AHandler
{
    public function handler()
    {
        $handled = false;
        
        // 處理請求
        echo 'Handler2接受到了請求' . PHP_EOL;
        
        if (!$handled && $this->nextHandler) {
            $this->nextHandler->handler();
        }
    }
}
class Handler3 extends AHandler
{
    public function handler()
    {
        $handled = false;
        
        // 處理請求
        echo 'Handler3接受到了請求' . PHP_EOL;
        
        if (!$handled && $this->nextHandler) {
            $this->nextHandler->handler();
        }
    }
}

使用代碼實例如下:

$handler1 = new Handler1();
$handler2 = new Handler2();
$handler3 = new Handler3();
$handler1->setNext($handler2);
$handler2->setNext($handler3);

$handler1->handler();

上述代碼雖然完成了責任鏈的結構,但還有一些問題,如果程序員對業務或責任鏈模式不太清楚的話,可能會忘記在handler方法里加入下面這段代碼:

if (!$handled && $this->nextHandler) {
    $this->nextHandler->handler();
}

那么就會造成責任鏈中斷。另外,如果我們的處理者有10個或者更多,那么就要new出10個處理者,然后還要執行9次setNext。如果一不小心,寫錯了,就尷尬了。

現在,我們修改下上述的代碼,修改后的代碼如下:

abstract class AHandler
{
    protected $nextHandler = null;
    
    public function setNext (AHandler $handler)
    {
        $this->nextHandler = $handler;
    }
    
    // 使用了模板方法模式,防止程序員忘記寫下段代碼
    public function handler ()
    {
        if (!$this->doHandler() && $this->nextHandler) {
            $this->nextHandler->handler();
        }
    }
    
    abstract public function doHandler ();
}

class Handler1 extends AHandler
{
    public function doHandler()
    {
        $handled = false;
        
        // 處理請求
        echo 'Handler1接受到了請求' . PHP_EOL;
        
        return $handled;
    }
}
class Handler2 extends AHandler
{
    public function doHandler()
    {
        $handled = false;
        
        // 處理請求
        echo 'Handler2接受到了請求' . PHP_EOL;
        
        return $handled;
    }
}

class Handler3 extends AHandler
{
    public function doHandler()
    {
        $handled = false;
        
        // 處理請求
        echo 'Handler3接受到了請求' . PHP_EOL;
        
        return $handled;
    }
}

class HandlerChain
{
    private $handlerChains = [];
    
    public function __construct(array $handlerChains)
    {
        $this->handlerChains = $handlerChains;
    }
    
    public function addHandler (AHandler $handler)
    {
        $this->handlerChains[] = $handler;
    }
    
    public function handler ()
    {
        $hdCnt = count($this->handlerChains);
        
        for ($i = 0; $i < $hdCnt; $i ++) {
            if (isset($this->handlerChains[$i]) 
                  && isset($this->handlerChains[$i+1])) {
                $this->handlerChains[$i]->setNext($this->handlerChains[$i+1]);
            }
        }
        
        $this->handlerChains[0]->handler();
    }
}

然后,使用代碼如下:

$handler1 = new Handler1();
$handler2 = new Handler2();
$handler3 = new Handler3();

$handerChian = new HandlerChain([$handler1, $handler2, $handler3]);
$handerChian->handler();

更簡單的實現方法

其實有一種更加簡單的實現責任鏈模式的方法,代碼如下:

abstract class AHandler
{
    abstract public function handler ();
}

class Handler1 extends AHandler
{
    public function handler()
    {
        $handled = false;
        // 處理請求
        echo 'Handler1接受到了請求' . PHP_EOL;
        return $handled;
    }
}

// Handler2、Handler3代碼省略


class HandlerChain
{
    private $handlerChains = [];
    
    public function __construct(array $handlerChains)
    {
        $this->handlerChains = $handlerChains;
    }
    
    public function addHandler (AHandler $handler)
    {
        $this->handlerChains[] = $handler;
    }
    
    public function handler ()
    {
        foreach ($this->handlerChains as $handler) {
            if ($handler->handler()) {
                break;
            }
        }
    }
}

總結

通過責任鏈模式,多個處理者都有機會處理請求。將原本的模塊分成多個處理者來處理,符合單一職責原則,代碼的可讀性也大大提高。另外,非常容易擴展,需要新的功能時,只要添加新的處理者即可。

一般設計模式的定義是,處理者如果不能夠處理該請求,就將請求傳遞給后一個處理者。其實,他也有一個變體,就是每個處理者都會處理請求。

上述就是小編為大家分享的什么是php中責任鏈模式了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關知識,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

苏尼特左旗| 根河市| 洛川县| 延津县| 岐山县| 双鸭山市| 勐海县| 延川县| 临江市| 万州区| 阳原县| 卓资县| 新竹市| 永安市| 左权县| 镇安县| 延边| 航空| 望谟县| 睢宁县| 银川市| 漳州市| 额尔古纳市| 禄丰县| 凉城县| 襄樊市| 大城县| 永福县| 深水埗区| 溧水县| 饶平县| 宕昌县| 旌德县| 吉木萨尔县| 安阳市| 庆阳市| 宁陕县| 梨树县| 河北区| 塔城市| 徐水县|