前言
其实一开始我是很纠结是否要写控制器的源码分析的,因为控制器的源码太少了,少到你不相信这是一个 MVC 里的一个重头。直觉里,大家都觉得控制器作为各个请求的“入口”,其后端应该有很多很多的代码支撑才可以的,然而事实相反,去掉注释后,一共才 60 行左右。
控制器之前
看控制器源码之前,我们还是要回顾一下,控制器是怎么来的。
请大家看截图,截图中有两个方法:分别是 createController 和 runController。
createController 负责把路由找到的 controller 类实例化。实例化时,可以看到 request 和 response 作为参数传递给了 controller 的构造方法,这也是为什么在定义 controller 时,如果定义了 __construct 方法一定要记得调用一下 parent::__construct() ,因为默认定义了 __construct 方法后会覆盖了父类的 __construct ,所以必须明确调用父类构造方法才能执行。
runController 是执行控制器过程,大致思路就是把刚刚实例话的对象拿过来,执行路由中找到的控制器方法。并且把输出返回。
控制器
严格来说,这个是控制器父类的源码。为控制器运行期间定义了一些常用的方法,如 post 参数验证,缓存等。下面具体说一下:
11-16 行:控制器父类的属性,这些属性可以定义控制器本身的状态。可以在自己定义的类中覆盖掉这些属性。 helpers 定义要加载的辅助方法,forceHTTPS 大于 0 时,可以指定当前设定值期间内强制到 https 。 validator 定义要验证的 post 内容的规则。
18-29 行:控制器父类的构造方法,在定义控制器时如果没定义自己的构造方法,这个方法会被默认执行,如果定义过将会覆盖掉这个方法,需要在构造方法的最前边执行 parent::__construct() 以保证这个方法中的初始化数据都能正常初始化。其中 forceHTTPS 方法是强制使用 https 协议,loadHelpers 可以默认自动加载需要的 helper 。
51-60 行: validate 方法,主要辅助验证 post 请求过来的各个字段。形式如下:
if (! $this->validate($this->request, [
'email' => "required|is_unique[users.email,id,{$userID}]",
'name' => 'required|alpha_numeric_spaces'
]))
{
return view('users/update', [
'errors' => $this->errors
]);
}
// do something here if successful...
以上源码截取自 CI 4 官方手册。如果觉得验证规则那个比较乱的话,可以在 ConfigValidation.php 中自定义一个验证组,并用以下方式验证:
$this->validate($this->request, 'userRules')
控制器之后
我们都知道,控制器会和 view 端交互,在之前的 CI 版本中,控制器会把 view load 进自己的生命周期中,直接处理 request 信息。个人也觉得这有些把 controller 的地位看得太重了。在 CI 4 中,控制器仅负责接到 view 返回的组装的页面字符串,并 return 回 codeigniter 核心中,由核心再处理后续事宜。
结语
本节简单的说了说控制器的父类,源码比较少,说的也就不多。下一节试着说说 view 。
此文可以转载,但转载前需要发邮件到imustgxd*sina.cn进行沟通,未沟通的均视作侵权。 转载同时需注明链接,并保留此段文字。
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。