Yii - 如果过滤器仅用于单个操作,它有什么好处


Yii - What is the benefit to a filter if it is only for a single action?

我正在学习一本Yii教程书,目前正在学习过滤器。 筛选器通常可以应用于控制器,也可以仅应用于特定操作。

我正在处理的示例是创建一个新问题。 每个问题都属于一个项目,因此我们添加一个过滤器以确保将project_id传递到issue/create页面。 由于issue/create是唯一需要project_id的页面,我们将过滤器应用于单个操作:

public function filters(){
    return array(
        'accessControl', // perform access control for CRUD operations
            'projectContext + create',//check to ensure valid project context
    );
}

我的问题是:如果过滤器仅适用于控制器中的单个操作,为什么不直接将filterProjectContext()代码放入actionCreate()函数中?

根据 yii 文档以及我对其他框架的经验,过滤器并不意味着与操作相结合。相反,过滤器允许您在 PHP 全局变量(例如$_REQUEST值)到达任何操作之前访问它们。例如,我参与的一个项目,如果传递了带有特定值的 url 参数,我们希望突出显示所有翻译的文本。我们本可以在控制器中执行此操作,但认为最好在筛选器中实现业务规则。过滤器最终看起来像:

// Symfony code, but should demonstrate the idea
if ($context->getRequest()->getParameter('highlightTranslations') === 'y') {
    // Tell translator API to highlight any subsequent translations
}

过滤器的优点在于,无论请求哪个操作,都会执行此代码。我的建议是不要将过滤器逻辑与操作逻辑混合在一起。