tp框架生命周期

1、入口文件

用户发起的请求都会经过应用的入口文件,通常是 public/index.php文件。当然,你也可以更改或者增加新的入口文件。

通常入口文件的代码都比较简单,一个普通的入口文件代码如下:

// 应用入口文件

// 定义项目路径
define('APP_PATH', __DIR__ . '/../application/');
// 加载框架引导文件
require __DIR__ . '/../thinkphp/start.php';

一般入口文件以定义一些常量为主,支持的常量请参考后续的内容或者附录部分。

通常,我们不建议在应用入口文件中加入过多的代码,尤其是和业务逻辑相关的代码。

2、引导文件

接下来就是执行框架的引导文件,start.php文件就是系统默认的一个引导文件。在引导文件中,会依次执行下面操作:

1.加载系统常量定义;
2.加载环境变量定义文件;
3.注册自动加载机制;
4.注册错误和异常处理机制;
5.加载惯例配置文件;
6.执行应用;
start.php引导文件首先会调用base.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
注册应用关闭方法是为了便于拦截一些系统错误。

在整个应用请求的生命周期过程中&#

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值