Yii框架中使用PHPExcel的方法分析


Posted in PHP onJuly 25, 2019

本文实例分析了Yii框架中使用PHPExcel的方法。分享给大家供大家参考,具体如下:

PHPExcel是一个比较好用的php读取excel文件的类库,今天遇到了在yii中如何加载PHPExcel类文件的问题,因为Yii的autoload机制是安装类名去找文件,即文件名就是相应的类名,而PHPExcel的类文件命名方式则是:dir_dir_classname.php,即文件名把文件的目录名都记录了,这种命名方式yii肯定识别不了。怎么办?

其实PHPExcel也有自己的autoload方法(PHPExcel_Autoloader::load() ),通过查看源码发现它也是通过spl_autoload_register函数注册的(在PHPExcel_Autoloader::register() 中),而我们知道PHP的autoload机制是,所有用spl_autoload_register函数注册的方法,都会在autoload时被spl_autoload_call函数执行一遍,因此我们只需要让PHPExcel的autoload方法顺利注册上就行了。

如果了解Yii的autoload机制,不清楚的可以看 附录 Yii的autoload机制 ,可以知道,只要设置Yii::$enableIncludePathfalse,第三方类库就有了执行自己的autoload方法的机会,然后使用下面两行代码就能加载PHPExcel的类了:

Yii::$enableIncludePath = false;
Yii::import('application.vendors.phpexcel.PHPExcel', 1);

import时采用了force include的方式,这是因为PHPExcel.php在被require时才会注册autoloader,如果等到new PHPExcel时才注册,其他的类例如PHPExcel_IOFactory如果在这之前使用了,就会出现找不到类的错误。

个人认为我的这种办法是比较方便且优雅的,对比网上的其他办法好很多,下面列举的办法都或多或少有点问题,例如:

1、https://3water.com/article/166128.htm,这种办法先将Yii自己的autoloader unregister了,会造成yii自己的类加载不上

2、https://3water.com/article/166132.htm,这种办法还修改了PHPExcel的autoloader,代价很大。

附录: Yii的autoload机制

Yii框架宣称自己的类加载方式很高效,是真正的“用时加载”,那究竟特别在哪里?今天研究了一下源码,发现其实是在代码级加了一层“路径缓存”。

我们知道,要实现自己的autoload方法,需要采用spl_autoload_register()函数注册一个autoload方法,Yii注册的这个方法是YiiBase::autoload(),稍后再讲解这个方法的逻辑。另外,Yii一般都用Yii::import($pathAlias, $forceInclude=false)来加载相应的类(这个方法直接调用了YiiBase::import() ),这个方法配合YiiBase::autoload()就能实现“用时加载”了。

先说import的大致逻辑:

1、检查self::$_imports数组是否存在相应的$pathAlias,如果有说明已经加载过了,直接返回类名或者目录名;否则继续第2步;

2、根据路径别名获得实际的路径名,并根据路径别名最后一部分是否是“*”可以知道要加载的路径别名是否是一个文件,如果是文件,去第3步;否则去第4步;

3、如果是$forceInclude是true,则立即require这个文件,并在$_imports数组中增加一项$alias => $className;否则在数组$classMap中缓存一项$className => $realPath

4、对于路径,会在数组$_includePaths中缓存这个路径,并且在$_imports数组中增加一项$alias => $realPath

5、结束。

因为$forceInclude默认都为false,所以import不会立即加载相应的类,等到使用时才真正加载,这是YiiBase::autoload的工作。

autoload的大致逻辑:

1、检查类名是否已缓存在$classMap或$_coreClasses数组中,如果是则直接require相应的文件路径,$_coreClasses是框架自有类的映射表;否则去第2步;

2、检测YiiBase::$enableIncludePath是否为false,如果是则去第3步,否则直接include($className . '.php')

3、遍历$includePaths数组,将目录名拼接上类名,检查是否为合法的php文件,如果是则include,然后跳出循环

4、结束。

需要注意的是,文档指出:如果要与其他类库一起使用,必须将$enableIncludePath置为false,以便在Yii::autoload()失败时,其他类库的autoload方法有机会执行。

希望本文所述对大家基于Yii框架的PHP程序设计有所帮助。

PHP 相关文章推荐
使用php+xslt在windows平台上
Oct 09 PHP
PHP+Mysql+jQuery实现动态展示信息
Oct 08 PHP
PHP命名空间(Namespace)简明教程
Jun 11 PHP
php解决抢购秒杀抽奖等大流量并发入库导致的库存负数的问题
Jun 19 PHP
避免Smarty与CSS语法冲突的方法
Mar 02 PHP
php实现的验证码文件类实例
Jun 18 PHP
PHP实现的线索二叉树及二叉树遍历方法详解
Apr 25 PHP
PHP利用二叉堆实现TopK-算法的方法详解
Apr 24 PHP
PHP实现的分页类定义与用法示例
Jul 05 PHP
ThinkPHP框架中使用Memcached缓存数据的方法
Mar 31 PHP
php获取手机端的号码以及ip地址实例代码
Sep 12 PHP
redis+php实现微博(一)注册与登录功能详解
Sep 23 PHP
PHP保留两位小数的几种方法
Jul 24 #PHP
Yii框架使用PHPExcel导出Excel文件的方法分析【改进版】
Jul 24 #PHP
Yii Framework框架使用PHPExcel组件的方法示例
Jul 24 #PHP
PHP+Apache实现二级域名之间共享cookie的方法
Jul 24 #PHP
PHP容器类的两种实现方式示例
Jul 24 #PHP
使用swoole 定时器变更超时未支付订单状态的解决方案
Jul 24 #PHP
thinkphp5.1框架容器与依赖注入实例分析
Jul 23 #PHP
You might like
一个php生成16位随机数的代码(两种方法)
2014/09/16 PHP
百度工程师讲PHP函数的实现原理及性能分析(二)
2015/05/13 PHP
PHP中addslashes()和stripslashes()实现字符串转义和还原用法实例
2016/01/07 PHP
php版微信自动获取收货地址api用法示例
2016/09/22 PHP
PHP GD库相关图像生成和处理函数小结
2016/09/30 PHP
PHP错误处理函数register_shutdown_function使用示例
2017/07/03 PHP
Docker搭建自己的PHP开发环境
2018/02/24 PHP
在Laravel5.6中使用Swoole的协程数据库查询
2018/06/15 PHP
multiSteps 基于Jquery的多步骤滑动切换插件
2011/07/22 Javascript
jQuery 网易相册鼠标移动显示隐藏效果实现代码
2013/03/31 Javascript
JavaScript 32位整型无符号操作示例
2013/12/08 Javascript
nodejs命令行参数处理模块commander使用实例
2014/09/17 NodeJs
排序算法的javascript实现与讲解(99js手记)
2014/09/28 Javascript
javascript类型系统 Window对象学习笔记
2016/01/07 Javascript
jQuery控制控件文本的长度的操作方法
2016/12/05 Javascript
解决vue2.x中数据渲染以及vuex缓存的问题
2017/07/13 Javascript
分享Bootstrap简单表格、表单、登录页面
2017/08/04 Javascript
基于casperjs和resemble.js实现一个像素对比服务详解
2018/01/10 Javascript
使用jquery Ajax实现上传附件功能
2018/10/23 jQuery
React Hooks的深入理解与使用
2018/11/12 Javascript
jQuery子选择器与可见性选择器实例分析
2019/06/28 jQuery
解决ele ui 表格表头太长问题的实现
2019/11/13 Javascript
Python学习小技巧之列表项的排序
2017/05/20 Python
Python堆排序原理与实现方法详解
2018/05/11 Python
树莓派使用USB摄像头和motion实现监控
2019/06/22 Python
Python 点击指定位置验证码破解的实现代码
2019/09/11 Python
python3.4中清屏的处理方法
2020/07/06 Python
css3学习之2D转换功能详解
2016/12/23 HTML / CSS
美国最大的无人机经销商:DroneNerds
2018/03/20 全球购物
大门门卫岗位职责
2013/11/30 职场文书
求职信写作要突出重点
2014/01/01 职场文书
自荐书范文范例
2014/02/13 职场文书
细节决定成败演讲稿
2014/05/12 职场文书
护理专业求职信
2014/06/15 职场文书
基层党员对照检查材料
2014/08/25 职场文书
2014物价局群众路线对照检查材料思想汇报
2014/09/21 职场文书