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'), ); 子命名空间分别对应顶级路径下的文件夹,如 AppLogicHttpControllerTestController对应路径是"{$baseDir} /App/Logic/HttpController"下的TestController.php 同时PSR-4要求文件名必须和类名保持完全一致,上述的TestController.php文件名由TesctController这个类名决定。
-
映射规则
vendor/ vendor_name/ package_name/ src/ ClassName.php # Vendor_NamePackage_NameClassName tests/ ClassNameTest.php # Vendor_NamePackage_NameClassNameTest
-
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的基本命令