thinkphp生命周期

1、入口文件

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

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

// 应用入口文件

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

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

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

2、引导文件

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

  • 加载系统常量定义;
  • 加载环境变量定义文件;
  • 注册自动加载机制;
  • 注册错误和异常处理机制;
  • 加载惯例配置文件;
  • 执行应用;

start.php引导文件首先会调用base.php基础引导文件,某些特殊需求下面可能直接在入口文件中引入基础引导文件。

如果在你的应用入口文件中更改了默认的引导文件,则上述执行流程可能会跟随发生变化。

3、注册自动加载

系统会调用 Loader::register()方法注册自动加载,在这一步完成后,所有符合规范的类库(包括Composer依赖加载的第三方类库)都将自动加载。

系统的自动加载由下面主要部分组成:

  1. 注册系统的自动加载方法  hinkLoader::autoload
  2. 注册系统命名空间定义
  3. 加载类库映射文件(如果存在)
  4. 如果存在Composer安装,则注册**Composer**自动加载
  5. 注册extend扩展目录

一个类库的自动加载检测顺序为:

  1. 是否定义类库映射;
  2. PSR-4自动加载检测;
  3. PSR-0自动加载检测;

可以看到,定义类库映射的方式是最高效的。

4、注册错误和异常机制

执行Error::register()注册错误和异常处理机制。

由三部分组成:

  • 应用关闭方法:thinkError::appShutdown
  • 错误处理方法:thinkError::appError
  • 异常处理方法:thinkError::appException

注册应用关闭方法是为了便于拦截一些系统错误。

在整个应用请求的生命周期过程中,如果抛出了异常或者严重错误,均会导致应用提前结束,并响应输出异常和错误信息。

5、应用初始化

执行应用的第一步操作就是对应用进行初始化,包括:

  • 加载应用(公共)配置;
  • 加载扩展配置文件(由extra_config_list定义);
  • 加载应用状态配置;
  • 加载别名定义;
  • 加载行为定义;
  • 加载公共(函数)文件;
  • 注册应用命名空间;
  • 加载扩展函数文件(由extra_file_list定义);
  • 设置默认时区;
  • 加载系统语言包;

6、URL访问检测

应用初始化完成后,就会进行URL的访问检测,包括PATH_INFO检测和URL后缀检测。

5.0的URL访问必须是PATH_INFO方式(包括兼容方式)的URL地址,例如:

http://serverName/index.php/index/index/hello/val/value

所以,如果你的环境只能支持普通方式的URL参数访问,那么必须使用

http://serverName/index.php?s=/index/index/hello&val=value

如果是命令行下面访问入口文件的话,则通过

$php index.php index/index/hello/val/value...

获取到正常的$_SERVER['PATH_INFO']参数后才能继续。

7、路由检测

如果开启了url_route_on参数的话,会首先进行URL的路由检测。

如果一旦检测到匹配的路由,根据定义的路由地址会注册到相应的URL调度。
5.0的路由地址支持如下方式:

    • 路由到模块/控制器/操作;
    • 路由到外部重定向地址;
    • 路由到控制器方法;
    • 路由到闭包函数;
    • 路由到类的方法;
原文地址:https://www.cnblogs.com/cuteur/p/14116346.html