控制器(Controller)
本节包含以下方面的内容
大部分的控制器都会处理一个Http的请求,然后返回Html或者Json或者Xml格式的数据作为响应。
1、基本概念
控制器文件一般在应用程序的 controllers目录下面,文件命名规则为 XXX Controller.php,其中XXX可以为任意的名称,后面的Controller是固定格式,不能少一个单词。
一个基本的控制器的定义要从 yii\web\Controller继承,如
一般来说控制器里面定义的动作都是
actionSomething格式的公共的方法。输出的数据可以是一个字符串或者yii\web\Response的实例。
动作输出的结果将会由 response组件处理并转换成不同的数据格式如JSON等。默认情况下是没有对动作的执行结果进行处理的。
2、路由
每个控制器里面的动作都有一个相对应的路由,在上面的例子中 actionIndex有一个对应的 site/index路由, actionTest对应的路由是 site/test。在这个路由中 site为控制器的id, test为动作的id。
一般情况下可以通过这个格式的URL来访问控制器和动作。 http://example.com/?r=controller/action。当然你可以完全自定义url的格式(URL Management.)。
如果控制器是在一个模块里面,
本节包含以下方面的内容
- 基本概念
- 路由
- 默认路由
- 默认路由
- 动作的参数
- 在动作中定义参数
- 从请求(request)中获取参数
- 独立动作
- 动作过滤器(Action Filters)
- 捕获所有的请求
- 自定义响应类
大部分的控制器都会处理一个Http的请求,然后返回Html或者Json或者Xml格式的数据作为响应。
1、基本概念
控制器文件一般在应用程序的 controllers目录下面,文件命名规则为 XXX Controller.php,其中XXX可以为任意的名称,后面的Controller是固定格式,不能少一个单词。
一个基本的控制器的定义要从 yii\web\Controller继承,如
- namespace app\controllers;
- use yii\web\Controller;
- class SiteController extends Controller
- {
- public function actionIndex()
- {
- // will render view from "views/site/index.php"
- return $this->render('index');
- }
- public function actionTest()
- {
- // will just print "test" to the browser
- return 'test';
- }
- }
动作输出的结果将会由 response组件处理并转换成不同的数据格式如JSON等。默认情况下是没有对动作的执行结果进行处理的。
2、路由
每个控制器里面的动作都有一个相对应的路由,在上面的例子中 actionIndex有一个对应的 site/index路由, actionTest对应的路由是 site/test。在这个路由中 site为控制器的id, test为动作的id。
一般情况下可以通过这个格式的URL来访问控制器和动作。 http://example.com/?r=controller/action。当然你可以完全自定义url的格式(URL Management.)。
如果控制器是在一个模块里面,