中文drupal教程1. 自动加载器与Composer
admin
2024-02-07 21:34:37
0

Drupal启动的第一步就是创建自动加载器,自动加载器是什么呢?它是怎么产生的?

自动加载器:

在面向对象的PHP程序开发的时候,要实例化一个类对象则需要先加载(require或include)类定义文件,当PHP发现并没有包含类定义文件时,并不会立即报错,它会去一个列队里面依次调用里面定义的函数或者方法,如果在这个过程中类定义文件被加载了,则返回继续实例化对象,程序可以没有问题的继续执行,否则程序报错,那么这个列队里面的函数或方法是怎么来的呢?它是由用户定义好,然后通过spl_autoload_register()注册进去的,这就是php的自动加载机制,spl_autoload_register()的使用方法请见:
  PHP: spl_autoload_register - Manual

Drupal是一个现代化的面向对象方式开发的软件,她即使用了这个自动加载机制,在实例化某个对象的时候,PHP依据类的完全限定名称(带名字空间前缀的类名)和文件路径的对应关系自动去 include文件,这个工作被封装在一个对象里面完成,这个对象的类定义文件位于:
  \vendor\composer\ClassLoader.php

在\vendor\composer\文件夹下你会看到如下几个文件:

autoload_classmap.php 里面是类到类定义文件的映射关系图
autoload_files.php 里面是全局需要加载的函数
autoload_namespaces.php 里面是PSR0映射关系
autoload_psr4.php 里面是PSR4映射关系

ClassLoader类加载器对象凭借这些文件里面定义的基本对应关系去查找Drupal运行所需的绝大部分函数和类定义文件,另外在此后的运行过程中,我们也可以动态的添加这种映射关系进去,以便更加灵活的进行加载。

实例化类加载器后(实例化过程中已经通过spl_autoload_register向PHP注册了加载处理函数),Drupal就不需要手动的 include一大堆文件了,省去了大量工作,说到这里你应该明白了什么是自动加载器和它的原理。

在以后的学习中,如果你使用的开发工具是phpstorm,并且开启了Drupal集成,那么可以按“Ctrl+N”并粘贴类的全限定名字空间名,就可以自动打开文件了,这样免去了手动到文件系统目录中查找,究其原因,phpstorm便是依据类加载对应机制自动实现的,该功能以后我们会多次使用。

如果你看过Drupal的index.php文件可能会奇怪为什么要中转几次才到\vendor\composer,其实是因为\vendor\composer里面的文件是自动生成的,此外\vendor目录里面的所有文件都是自动生成的(vendor目录储存Drupal运行所依赖的第三方程序库),这是怎么回事?是谁生成了她们?她就是大名鼎鼎的composer

Composer(依赖管理工具):

composer被设计用于PHP程序的依赖管理,简单点说就是现代PHP项目或多或少会用到第三方程序库,那么如何保持第三方库的更新?如何下载?多个协作者如何保持版本统一?第三方库又互相依赖或多级依赖怎么处理?这需要一个自动化的解决方案,于是composer产生了。

composer用于解决上述问题,它本身是一个用php写成的应用程序,被封装成了composer.phar,运行在php之上,帮助你下载第三方组件库,保持版本统一,产生自动加载器的源代码等等,Drupal的\vendor目录就是她自动产生的。下面我们来学习一下它的用法:

先安装composer,所谓安装其实就是下载它的执行文件composer.phar,如果需要方便一点再把它加入操作系统的环境变量,这里为叙述方便,假定你使用的是window系统,PHP已经被添加到环境变量中,composer.phar无需添加到环境变量中,实验目录为C:\root\test\composer:

首先下载composer.phar,官网 有几种安装方式,可以用命令行安装,也可以直接下载,打开Composer查看页面底部,Manual Download手动下载,选择最新的一个版本,下载保存到C:\root\test\composer中。

composer是通过composer.json文件来解析并自动下载第三方库的,也据此生成加载器所需的对应文件,下载完成会生成一个composer.lock文件,用于固定协同开发者的第三方版本,关于composer.json怎么制作那是使用第三方库的项目开发者的责任,请参考官方文档,这里复制Drupal根目录的composer.json、composer.lock到C:\root\test\composer中,打开命令行(开始菜单>cmd),请确保PHP被添加到了系统环境变量,运行下面的命令:

    cd C:\root\test\composer php composer.phar  install 

此时程序开始下载第三方库,并产生自动加载器,多出一个C:\root\test\composer\vendor目录

进去看一看,对比一下于Drupal根目录下面的/vendor是不是一模一样呢?

关于composer的更多介绍请到其官方网站:
Composer

作者声明:
伴随Drupal不断发布的新版本,本系列教程持续更新,适用于Drupal V8、V9、V10以及后续版本,如未及时更新请反馈。
本Drupal教程为中文原创,并非翻译,来自作者耗时八年对源代码的理解,最初取名为“云客Drupal源码分析”并在社区发布。
作者:云客,微信号及个人网站域名均为“indrupal”;首发于云客个人网站“水滴间”,已发布一百余万字,持续更新中。
鸣谢“未来很美科技”提供的赞助支持,“未来很美(深圳)科技有限公司”是国内专业的Drupal开发公司,总部位于深圳。
如对您有帮助可到“水滴间”进行赞助支持,同时Drupal中国社区需要大家共建共享,云客持开放态度与大家合作推进。
允许任何机构以及个人转载、翻译、引用传播等,但须同步附带本声明。

相关内容

热门资讯

容芯致远获天使轮融资 2026年5月8日,北京容芯致远科技有限公司(简称“容芯致远”)宣布完成天使轮融资。本轮融资由万利达...
试管期间能运动吗?避开这些坑,... 做试管的姐妹都纠结:不动怕气血差、影响卵泡,动了又怕伤子宫、毁着床,到底该怎么办?其实试管不用“躺平...
原创 今... 2026年5月6日,国内金价算是彻底“凉”了一下,你看那AU9999现货黄金,直接跌到了1013元一...
美国5月消费者信心再创历史新低... 财联社5月8日讯(编辑 牛占林)随着中东战争持续推高能源价格,美国消费者信心本月继续下滑,并再度刷新...
“压高盛一头”!江西一精神病院... 蓝鲸新闻5月8日讯(记者 徐甘甘)5月8日,盛通股份(002599.SZ)一季报引发资本市场热议——...
2026年企业短视频能力升级:... 本篇将回答的核心问题 2026年企业短视频营销面临哪些关键挑战,有效应对策略是什么? 服务机构的能力...
江西一精神病院炒股炒成上市公司... 红星资本局5月8日消息,近日,上市公司盛通股份(002599.SZ)发布一季报,披露了前十大股东名单...
企业IP打造指南:小公司低成本... 小公司做企业IP,不是为了装门面,而是让客户在没见到你之前,就能通过内容知道你是谁、你解决什么问题、...
官方:赵心童入选世界斯诺克名人... 北京时间5月8日消息,世界斯诺克巡回赛(WST)今日正式公布了2025/26赛季年终奖项及名人堂更新...
小灰熊AI学员王锋:希望能跟上... 35了,老程序员了。 从进入互联网行业到现在,其实已经做了很多年移动端开发。最早那几年,安卓行业发展...
原创 2... 2026年全国两会把稳定房地产市场列为重点工作,政府工作报告明确提出因城施策控增量、去库存、优供给。...
一年翻倍,六年未归——徽商银行... 文:向善财经 今年的港股市场,与A股市场出现了明显的分化。 A股这边,科技板块在AI浪潮中热闹非凡;...
古井贡酒2025:在行业深度调... 以“稳”为底、以“新”为翼。 文/每日财报 杜康 在行业库存高企、价格倒挂的背景下,当多数酒企在为...
好上好8408万收购鼎瑞芯加码... 5月7日晚,好上好(001298.SZ)抛出一份收购公告,拟以8408万元现金收购深圳市鼎瑞芯科技有...
全面大撤离!李嘉诚英国“套现”... 突发,李嘉诚又卖了。 这次,套现了455亿。 金额不少,但更值得关注的是透露着不同寻常的信号。 因为...
油气价格上涨加剧法国一季度贸易... 据新华社,法国海关7日发布的数据显示,受中东局势推高国际油气价格影响,法国今年第一季度贸易逆差扩大至...
昆仑芯启动科创板IPO上市辅导... 5月8日,据证监会官网显示,昆仑芯(北京)科技股份有限公司于2026年5月7日正式启动科创板上市辅导...
贵州茅台酒股份有限公司关于回购... 来源:上海证券报 证券代码:600519 证券简称:贵州茅台 公告编号:临2026-016 贵州茅...
百度昆仑芯启动科创板上市辅导,... 5月8日,证监会官网显示,昆仑芯(北京)科技股份有限公司 (下称“昆仑芯”)于2026年5月7日正式...
滕州信华的承压时刻:罚单、失信... 2026年4月末,滕州信华美元债单日跌近2%,关联方被列“老赖”。半年前,这家AA+城投曾因非市场化...