本文实例讲述了thinkPHP5.0框架应用请求生命周期。分享给大家供大家参考,具体如下:
本篇内容我们对ThinkPHP5.0的应用请求的生命周期做大致的介绍,以便于开发者了解整个执行流程。
1、入口文件
用户发起的请求都会经过应用的入口文件,通常是 public/index.php文件。当然,你也可以更改或者增加新的入口文件。
通常入口文件的代码都比较简单,一个普通的入口文件代码如下:
// 应用入口文件// 定义项目路径define('APP_PATH', __DIR__ . '/../application/');// 加载框架引导文件require __DIR__ . '/../thinkphp/start.php';
一般入口文件已定义一些常量为主,支持的常量请参考后续的内容或者附录部分。
通常,我们不建议在应用入口文件中加入过多的代码,尤其是和业务逻辑相关的代码。
2、引导文件
接下来就是执行框架的引导文件,start.php文件就是系统默认的一个引导文件。在引导文件中,会依次执行下面操作:
① 加载系统常量定义;
② 加载环境变量定义文件;
③ 注册自动加载机制;
④ 注册错误和异常处理机制;
⑤ 加载惯例配置文件;
⑥ 执行应用;
如果在你的应用入口文件中更改了默认的引导文件,则上述执行流程可能会跟随发生变化。
3、注册自动加载
系统会调用Loader::register()方法注册自动加载,在这一步完成后,所有符合规范的类库(包括Composer依赖加载的第三方类库)都将自动加载。
系统的自动加载由两个部分组成:
① 注册系统的自动加载方法 /think/Loader::autoload
② 注册系统命名空间定义
③ 加载类库映射文件(如果存在)
④ 如果存在Composer安装,则注册Composer自动加载
⑤ 注册Extend扩展目录
一个类库的自动加载检测顺序为:
① 是否定义类库映射;
② PSR-4自动加载检测;
③ PSR-0自动加载检测;
可以看到,定义类库映射的方式是最高效的。
4、注册错误和异常机制
执行Error::register()注册错误和异常处理机制。
由三部分组成:
① 应用关闭方法:think/Error::appShutdown
② 错误处理方法:think/Error::appError
③ 异常处理方法:think/Error::appException
注册应用关闭方法是为了便于拦截一些系统错误。
在整个应用请求的生命周期过程中,如果抛出了异常或者严重错误,均会导致应用提前结束,并响应输出异常和错误信息。
5、应用初始化
执行应用的第一步操作就是对应用进行初始化,包括:
加载应用(公共)配置;
加载应用状态配置;
加载别名定义;
新闻热点
疑难解答