使用基本的Controller (Using base controller) 在很多框架的手册中都会对base controller的扩展进行描述。但在yii手册中并没有相应的内容,因为你可以用许多方式很容易的对base controller进行扩展。尽管如此,我们还是来说说base controller,但还是非常有用的。
准备工作(Getting ready) 使用yiic webapp建立一个新项目。
比方说,我们要添加一些只有登录用户才能访问的controller。当然,我们可以为每个controller单独设定这些规则,但其实我们有更好的方法。 怎样去做...(How to do it ...)
1. 首先,我们需要一个基类。让我们在protected/components目录下创建一个名为SecureController.php的类,代码如下:
<?php
class SecureController extends Controller
{
public function filters()
{
return array(
'accessControl',
);
}
public function accessRules()
{
return array(
array('allow',
'users'=>array('@'),
),
array('deny',
'users'=>array('*'),
),
);
}
}
2.现在,我们用Gii生成controller,生成时指明BaseClass为SecureController。这样,你将得到类似下面的代码:
class TestController extends SecureController
{
public function actionIndex()
{
$this->render('index');
}
…
}
3.现在,虽然你还没有在TestController中进行任何访问规则声明,但TestController的index只能被登录用户访问了。
工作原理...(How it works...) 方法很简单,只是使用了基类继承。如果TestController中不存在filters或accessRules,那么将调用基类SecureController中的相应方法。