composer分析(二)结合PSR-4


  • PSR-4提供了一种文件和路径映射关系,非常类似文件系统的组织结构

  • 全限定类名

    \<NamespaceName>(\<SubNamespaceNames>)*\<ClassName>
    规定了类必须有一个顶级命名空间,可以有多个子命名空间。
    顶级命名空间和目录对应的关系相对特殊,可在autoload_psr4.php中查看
    映射关系是一个数组,是因为composer支持从多个目录下加载同一个命名空间前缀
    $vendorDir = dirname(dirname(__FILE__));
    $baseDir = dirname($vendorDir);
    return array(
    'Psr\\Http\\Message\\' => array($vendorDir . '/psr/http-message/src'),
    'Opis\\Closure\\' => array($vendorDir . '/opis/closure/src'),
    'FastRoute\\' => array($vendorDir . '/nikic/fast-route/src'),
    ...
    'App\\' => array($baseDir . '/App'),
    ); 子命名空间分别对应顶级路径下的文件夹,如 App\Logic\HttpController\TestController对应路径是"{$baseDir} /App/Logic/HttpController"下的TestController.php 同时PSR-4要求文件名必须和类名保持完全一致,上述的TestController.php文件名由TesctController这个类名决定。
  • 映射规则

    vendor/
    vendor_name/
    package_name/
    src/
    ClassName.php # Vendor_Name\Package_Name\ClassName
    tests/
    ClassNameTest.php # Vendor_Name\Package_Name\ClassNameTest
  • composer文件夹下的文件

    autoload_classmap.php  // 保存类文件和真实路径映射
    autoload_files.php // 保存全局函数文件和路径映射
    autoload_psr4.php // 保存顶级命名空间和路径映射
    autoload_static.php // 保存composer加载器解析过程中需要用到的映射关系数组
    ClassLoader.php
    此文件中的findFile方法会先查找classmap中是否存在需要加载类的映射,如果不存在会先根据上文描述的PSR-4规则拼接文件的真实路径,没找到还会走PSR-0规则。最后然会文件的绝对路径include完成文件的加载。可以看到如果存在类路径映射会非常快的实现类的自动加载,就不需要文件系统的检查了。
    如何生成类映射关系: 执行命令 composer dump-autoload (-o),生产环境建议执行,因为从classmap中直接返回映射关系,便不需要再去动态读取PSR加载规范了,可减少文件系统的操作,提升部分性能
  • 有兴趣的可以打印composer返回的自动加载器对象,允许我们在引入autoload.php文件后动态添加各种的映射关系


下集预告:composer的基本命令

05-11 23:04