深入理解PHP之require&include顺序
在大型的Web项目中, include_path是一个模块化设计的根本中的根本(当然,现在也有很多基于autoload的设计, 这个不影响本文的探讨), 但是正是因为include_path, 经常会让我们遇到一些因为没有找到正确的文件而导致的看似”诡异”的问题. 也就有了如下的疑问: include_path是怎么起作用的? 如果有多个include_path顺序是怎么样的? 什么情况下include_path不起作用? 今天, 我就全面的介绍下这个问题, 先从一个例子开始吧. 如下的目录结构: root ├ 1.php ├ 3.php └ subdir ├ 2.php └ 3.php 在1.php中: 而在2.php中: 而在root目录下的3.php打印出”root”, 在subdir目录下的3.php打印出”subdir”; 现在, 我的问题来了: 1. 当在root目录下运行1.php, 会得到什么输出? 2. 在subdir下运行上一级目录的1.php, 有会得到什么输出? 3. 当取消include_path中的当前目录path(也就是include_path=”path_to_subdir”), 上面俩个问题又会是什么输出? PHP中的include_path PHP在遇到require(_once)/include(_once)的指令的时候, 首先会做如下的判断: 要包含的文件路径是绝对路径么? 如果是, 则直接包含, 并结束. 如果不是, 进入另外的逻辑(经过多次调用, 宏展开后进入_php_stream_fopen_with_path)寻找此文件. 接下来, 在_php_stream_fopen_with_path中, 会做如下判断: 要包含的文件路径是相对路径么(形如./file, ../dir/file, 以下用"目录相对路径代替")? 如果是, 则跳过include_path的作用逻辑, 直接解析相对路径(随后单独介绍). 会根据include_path,和当前执行文件的path组成一个待选的目录列表, 比如对于文章前面的例子来说, 会形成一个如下的待选列表 ".:path_to_subdir:current_script_dir" 然后, 依次从待选列表头部开始, 根据DEFAULT_DIR_SEPARATOR(本文的环境是”:”)取出待选列表中的一个路径, 然后把要
Published at 3 months ago