<?PHP/** * copyright (C) Alibaba Cloud Computing * All rights reserved */$version = '0.6.0';function Aliyun_Log_PHP_ClIEnt_autoload($classname) { $classpath = explode('_', $classname); if ($classpath[0] == 'Aliyun') { if(count($classpath)>4) $classpath = array_slice($classpath, 0, 4); $filePath = dirname(__file__) . '/' . implode('/', $classpath) . '.PHP'; if (file_exists($filePath)) require_once($filePath); }}spl_autoload_register('Aliyun_Log_PHP_ClIEnt_autoload');
上面自动加载方法会与原有框架自己的加载方法冲突,解决方法如下:
<?PHPfunction autoloadAdjust(){ // 取原有的加载方法 $oldFunctions = spl_autoload_functions(); // 逐个卸载 if ($oldFunctions){ foreach ($oldFunctions as $f) { spl_autoload_unregister($f); } } // 注册本框架的自动载入 spl_autoload_register( # 就是aliyun sdk的加载方法 function ($classname) { $classpath = explode('_', $classname); if ($classpath[0] == 'Aliyun') { if(count($classpath)>4) $classpath = array_slice($classpath, 0, 4); unset($classpath[0]); $filePath = dirname(__file__) . '/' . implode('/', $classpath) . '.PHP'; if (file_exists($filePath)) require_once($filePath); } } ); // 如果引用本框架的其它框架已经定义了__autoload,要保持其使用 if (function_exists('__autoload')) { spl_autoload_register('__autoload'); } // 再将原来的自动加载函数放回去 if ($oldFunctions){ foreach ($oldFunctions as $f) { spl_autoload_register($f); } }}# 最后调用上面方法autoloadAdjust();
注意在引入时,按照上面方法使用可能要改变代码中的文件路径
参考:
总结近日,开发中,使用了ZF框架和一个自有框架进行配合.
先启动了ZF, 之后,启动自有框架, 这时发现 自有框架的自动加载 不生效.
双方都使用了 spl_autoload_register 对自动加载方法进行了 注册.
分析后发现, ZF的加载方法,在发现无法加载时, 直接报错, 而没有把控制权转交给下一个自动加载方法.
如果先注册自有框架的加载方法,就不会出问题.因为自有框架的自动加载方法 找不到类时,会返回False,这将控制权转交给下一个加载方法
项目状态导致注册顺序只能是ZF在前面. 查了手册 写了下面的程序来调整注册顺序
以上是内存溢出为你收集整理的php 解决项目中多个自动加载冲突问题全部内容,希望文章能够帮你解决php 解决项目中多个自动加载冲突问题所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)