| 对于管道模式来说,有3个对象:管道,载荷,过滤器。 我们的目的是在管道中对载荷进行一系列的处理。因为可以对过滤器进行动态的添加,所以对载荷的处理可以变得更加灵活。但同时带来的问题是,在过滤器过多时,
 我们很难把握整体的处理逻辑。而且在某一个过滤器对载荷处理后,因为载荷改变, 会造成下一个过滤器中的逻辑出错。
 <?php
interface StageInterface
{
    public function handle($payLoad);
}
interface PipelineInterface
{
    public function __construct($payLoad);
 
    public function pipe(StageInterface $stage);
 
    public function process();
}
 
 
class JwtVerify implements StageInterface
{
    public function handle($payLoad)
    {
    	if(0){
    		return '权限检验失败';
		}
        return $payLoad + 1;
    }
}
class AddLog StageInterface
{
    public function handle($payLoad)
    {
        return $payLoad + 2;
    }
}
 
class Pipeline implements PipelineInterface
{
    private $pipes;
    private $payLoad;
 
    public function __construct($payLoad)
    {
        $this->payLoad = $payLoad;
    }
 
    public function pipe(StageInterface $stage)
    {
        $this->pipes[] = $stage;
        return $this;
    }
 
    public function process()
    {
        foreach ($this->pipes as $eachPipe)
        {
            $this->payLoad = call_user_func([$eachPipe, 'handle'], $this->payLoad);
        }
 
        return $this->payLoad;
    }
}
 
 
class Action
{
    public function run()
    {
    	
        $payLoad = 10;
 
		
        $jwtVerify = new JwtVerify();
        $addLog= new AddLog();
 
        $pipe = new Pipeline($payLoad);
 
 		
        return $pipe->pipe($jwtVerify)->pipe($addLog)->process();
    }
}
 
$test = new Action();
$test->run();
  
 在我们的示例中:管道类是Pipeline,载荷是在实例化Pipeline时传递的payLoad,过滤器是所有实现StageInterface的类。在web应用中,在服务器将请求分发给php的web入口文件到到达具体处理请求的文件的周期中,我们可以对request这个载荷的处理,可以应用管道模式(如thinkphp6的中间件)。 |