前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >ThinkPHP框架运行流程

ThinkPHP框架运行流程

作者头像
PM吃瓜
发布2019-08-13 10:56:46
1.1K0
发布2019-08-13 10:56:46
举报
文章被收录于专栏:PM吃瓜(公众号)

1. 用户URL请求

2. 调用应用入口文件(通常是网站的index.php)

3. 载入框架入口文件(ThinkPHP.php)

4. 记录初始运行时间和内存开销

(引用自ThinkPHP.php)

// 记录开始运行时间

$GLOBALS['_beginTime'] = microtime(TRUE);

// 记录内存初始使用

define('MEMORY_LIMIT_ON',function_exists('memory_get_usage'));

if(MEMORY_LIMIT_ON) $GLOBALS['_startUseMems'] = memory_get_usage();

5. 系统常量判断及定义

(引用自ThinkPHP.php)

// 系统常量定义

defined('THINK_PATH') or define('THINK_PATH', DIR .'/');

defined('APP_PATH') or define('APP_PATH', dirname($_SERVER['SCRIPT_FILENAME']).'/'); defined('APP_STATUS') or define('APP_STATUS', ''); // 应用状态 加载对应的配置文件defined('APP_DEBUG') or define('APP_DEBUG', false); // 是否调试模式

6. 载入框架引导类(Think\Think)并执行Think::start方法进行应用初始化

(引用自ThinkPHP.php)

// 应用初始化

Think\Think::start();

7. 设置错误处理机制和自动加载机制

(引用Think.class.php)

// 注册AUTOLOAD方法

spl_autoload_register('Think\Think::autoload');

// 设定错误和异常处理

register_shutdown_function('Think\Think::fatalError');

set_error_handler('Think\Think::appError'); set_exception_handler('Think\Think::appException');

8. 调用Think\Storage类进行存储初始化(由STORAGE_TYPE常量定义存储类型)

(引用Think.class.php)

// 初始化文件存储方式

Storage::connect(STORAGE_TYPE);

9. 部署模式下如果存在应用编译缓存文件则直接加载(直接跳转到步骤22)

(引用Think.class.php)

if(!APP_DEBUG && Storage::has($runtimefile)){

Storage::load($runtimefile);

}

10. 读取应用模式(由APP_MODE常量定义)的定义文件(以下以普通模式为例说明)

Thinkphp框架默认的应用模式 为普通模式。

(引用Think.class.php)

// 读取应用模式

$mode = include is_file(CONF_PATH.'core.php')?CONF_PATH.'core.php':MODE_PATH.APP_MODE.'.php';

11. 加载当前应用模式定义的核心文件(普通模式是 ThinkPHP/Mode/common.php) (common.php)

THINK_PATH.'Conf/convention.php', // 系统惯例配置

CONF_PATH.'config'.CONF_EXT, // 应用公共配置

12. 加载惯例配置文件(普通模式是 ThinkPHP/Conf/convention.php)

13. 加载应用配置文件(普通模式是 Application/Common/Conf/config.php)

14. 加载系统别名定义

(common.php)

// 别名定义

'alias' => array(

'Think\Log' => CORE_PATH . 'Log'.EXT, 'Think\Log\Driver\File' => CORE_PATH . 'Log/Driver/File'.EXT, 'Think\Exception' => CORE_PATH . 'Exception'.EXT, 'Think\Model' => CORE_PATH . 'Model'.EXT,

'Think\Db' => CORE_PATH . 'Db'.EXT,

'Think\Template' => CORE_PATH . 'Template'.EXT, 'Think\Cache' => CORE_PATH . 'Cache'.EXT, 'Think\Cache\Driver\File' => CORE_PATH . 'Cache/Driver/File'.EXT, 'Think\Storage' => CORE_PATH . 'Storage'.EXT,

),

15. 判断并读取应用别名定义文件(普通模式是 Application/Common/Conf/alias.php)

16. 加载系统行为定义

17. 判断并读取应用行为定义文件(普通模式是 Application/Common/Conf/tags.php)

(tags.php)

'app_init'=>array('Common\Behavior\InitHookBehavior')

18. 加载框架底层语言包(普通模式是 ThinkPHP/Lang/zh-cn.php)

19. 如果是部署模式则生成应用编译缓存文件

20. 加载调试模式系统配置文件(ThinkPHP/Conf/debug.php)

21. 判断并读取应用的调试配置文件(默认是 Application/Common/Conf/debug.php)

22. 判断应用状态并读取状态配置文件(如果APP_STATUS常量定义不为空的话)

(think.class.php)

// 读取当前应用状态对应的配置文件

if(APP_STATUS && is_file(CONF_PATH.APP_STATUS.CONF_EXT))

C(include CONF_PATH.APP_STATUS.CONF_EXT);

23. 检测应用目录结构并自动生成(如果CHECK_APP_DIR配置开启并且RUNTIME_PATH目录不存在的情况下)

think.class.php

// 检查应用目录结构 如果不存在则自动创建

if(C('CHECK_APP_DIR')) {

$module = defined('BIND_MODULE') ? BIND_MODULE : C('DEFAULT_MODULE');

if(!is_dir(APP_PATH.$module) || !is_dir(LOG_PATH)){

// 检测应用目录结构

Build::checkDir($module);

}

}

24. 调用Think\App类的run方法启动应用

think.class.php

// 运行应用

App::run();

25. 应用初始化(app_init)标签位侦听并执行绑定行为

26. 判断并加载动态配置和函数文件

27. 调用Think\Dispatcher::dispatch方法进行URL请求调度

App.class.php

Dispatcher::dispatch();

28. 自动识别兼容URL模式和命令行模式下面的$_SERVER['PATH_INFO']参数

Dispatcher.class.php

$_SERVER['PATH_INFO'] = $_GET[$varPath];

29. 检测域名部署以及完成模块和控制器的绑定操作(APP_SUB_DOMAIN_DEPLOY参数开启)

Dispatcher.class.php

30. 分析URL地址中的PATH_INFO信息

Dispatcher.class.php

31. 获取请求的模块信息

32. 检测模块是否存在和允许访问

33. 判断并加载模块配置文件、别名定义、行为定义及函数文件

34. 判断并加载模块的动态配置和函数文件

35. 模块的URL模式判断

36. 模块的路由检测(URL_ROUTER_ON开启)

Dispatcher.class.php

37. PATH_INFO处理(path_info)标签位侦听并执行绑定行为

38. URL后缀检测(URL_DENY_SUFFIX以及URL_HTML_SUFFIX处理)

39. 获取当前控制器和操作,以及URL其他参数

40. URL请求调度完成(url_dispatch)标签位侦听并执行绑定行为

41. 应用开始(app_begin)标签位侦听并执行绑定行为

App.class.php

static public function run() {

// 应用初始化标签

Hook::listen('app_init');

App::init();

// 应用开始标签

Hook::listen('app_begin');

42. 调用SESSION_OPTIONS配置参数进行Session初始化(如果不是命令行模式)

// Session初始化

if(!IS_CLI){

session(C('SESSION_OPTIONS'));

}

43. 根据请求执行控制器方法

44. 如果控制器不存在则检测空控制器是否存在

45. 控制器开始(action_begin)标签位侦听并执行绑定行为

Controller.class.php

public function construct() { Hook::listen('action_begin',$this->config);

//实例化视图类

$this->view = Think::instance('Think\View');

//控制器初始化if(method_exists($this,'_initialize'))

$this->_initialize();

}

46. 默认调用系统的ReadHtmlCache行为读取静态缓存(HTML_CACHE_ON参数开启)

47. 判断并调用控制器的_initialize初始化方法

Controller.class.php

if(method_exists($this,'_initialize'))

$this->_initialize();

48. 判断操作方法是否存在,如果不存在则检测是否定义空操作方法

49. 判断前置操作方法是否定义,有的话执行

50. Action参数绑定检测,自动匹配操作方法的参数

51. 如果有模版渲染(调用控制器display方法)

52. 视图开始(view_begin)标签位侦听并执行绑定行为

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2019-01-18,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 Tech爬虫 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
文件存储
文件存储(Cloud File Storage,CFS)为您提供安全可靠、可扩展的共享文件存储服务。文件存储可与腾讯云服务器、容器服务、批量计算等服务搭配使用,为多个计算节点提供容量和性能可弹性扩展的高性能共享存储。腾讯云文件存储的管理界面简单、易使用,可实现对现有应用的无缝集成;按实际用量付费,为您节约成本,简化 IT 运维工作。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档