文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

tp5.1框架一

2023-09-18 16:26

关注

1、index.php

位置:public/index.php

作用:

系统入口、常量定义、加载base.php、启动程序。

加载 thinkphp/base.php,并用Container类启动应用。

2、base.php

位置:thinkphp/base.php

thinkphp为php核心类库,5.1的核心类库不用composer加载,即thinkphp和vendor是同一文件夹下两个文件。

作用:

加载Loader.php,加载类和异常处理,实现日志接口,注册类库别名。

注册的别名大多都是think\facade中的类,包括App、Build、Cache、Config、Cookie、Db、Debug、Env、Facade、Hook、Lang、Log、Request、Response、Route、Session、Url、Validate、View。设置别名则代表创建think\App等类,在之后的代码中可以直接使用think\App。其他版本中若没有设置别名,则需使用think\facade\App等,这应该也是我用别的版本使用think\Log报错的原因。

3、Loader.php

位置:thinkphp/library/think/loader.php

作用:

主要功能就是加载类。

base.php 文件中有register()和addClassAlias()方法的使用。

该文件中根目录为public上层目录,若使用命令行则为脚本使用的目录。

register()首先调用autoload(),改方法若有参数则在对应数组中查找文件路径并直接加载文件。

之后自动加载根目录下/vendor/composer/autoload_static.php。

这段挺有意思

public static function register($autoload = '')    {        // 注册系统自动加载        spl_autoload_register($autoload ?: 'think\\Loader::autoload', true, true);        $rootPath = self::getRootPath();        self::$composerPath = $rootPath . 'vendor' . DIRECTORY_SEPARATOR . 'composer' . DIRECTORY_SEPARATOR;        // Composer自动加载支持        if (is_dir(self::$composerPath)) {            if (is_file(self::$composerPath . 'autoload_static.php')) {                require self::$composerPath . 'autoload_static.php';                $declaredClass = get_declared_classes();                $composerClass = array_pop($declaredClass);                foreach (['prefixLengthsPsr4', 'prefixDirsPsr4', 'fallbackDirsPsr4', 'prefixesPsr0', 'fallbackDirsPsr0', 'classMap', 'files'] as $attr) {                    if (property_exists($composerClass, $attr)) {                        self::${$attr} = $composerClass::${$attr};                    }                }            } else {                self::registerComposerLoader(self::$composerPath);            }        }        // 注册命名空间定义        self::addNamespace([            'think' => __DIR__,            'traits' => dirname(__DIR__) . DIRECTORY_SEPARATOR . 'traits',        ]);        // 加载类库映射文件        if (is_file($rootPath . 'runtime' . DIRECTORY_SEPARATOR . 'classmap.php')) {            self::addClassMap(__include_file($rootPath . 'runtime' . DIRECTORY_SEPARATOR . 'classmap.php'));        }        // 自动加载extend目录        self::addAutoLoadDir($rootPath . 'extend');    }public static function registerComposerLoader($composerPath)    {        if (is_file($composerPath . 'autoload_namespaces.php')) {            $map = require $composerPath . 'autoload_namespaces.php';            foreach ($map as $namespace => $path) {                self::addPsr0($namespace, $path);            }        }        if (is_file($composerPath . 'autoload_psr4.php')) {            $map = require $composerPath . 'autoload_psr4.php';            foreach ($map as $namespace => $path) {                self::addPsr4($namespace, $path);            }        }        if (is_file($composerPath . 'autoload_classmap.php')) {            $classMap = require $composerPath . 'autoload_classmap.php';            if ($classMap) {                self::addClassMap($classMap);            }        }        if (is_file($composerPath . 'autoload_files.php')) {            self::$files = require $composerPath . 'autoload_files.php';        }    }

找到autoload_static.php文件之间返回路径,但之后还有代码估计是忘改了。

找不到autoload_static.php文件再找autoload_namespaces.php、autoload_psr4.php、autoload_classmap.php、autoload_files.php,找到后加到对应的数组里。

因为核心文件和vendor是分开的,找完这些文件还要加载核心文件,也是加到对应数组里。

再加载映射文件,为runtime/classmap.php文件,最后加载extend文件夹下的文件。

这些加载过程将项目中用到的文件的路径全部获取到,用于之后动态调用加载。

Loader::register()使用spl_autoload_register('think\\Loader::autoload'')将使用为定义的类时触发Loader::autoload()方法,实现动态加载类。

所以base.php里Error::register()先调用Loader::autoload()加载文件再调用Error::register()

总结以上内容动态加载类的方法为,先加载全部文件路径,再用spl_autoload_register()实现动态加载对应路径的文件的类。

4、Error.php

位置:thinkphp/library/think/Error.php

作用:

Error::register()方法

 public static function register()    {        error_reporting(E_ALL);        set_error_handler([__CLASS__, 'appError']);        set_exception_handler([__CLASS__, 'appException']);        register_shutdown_function([__CLASS__, 'appShutdown']);    }

error_reporting()设置报错级别,这里是全部。

set_error_handler() 函数设置用户自定义的错误处理函数,这里是Error::appError()。

set_exception_handler() 函数设置用户自定义的异常处理函数,Error::appException()。

register_shutdown_function()该函数是来注册一个会在PHP中止时执行的函数,Error::appShutdown()。

来源地址:https://blog.csdn.net/lsswear/article/details/126429667

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯