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脚本数据库功能详解(下)
Oct 09 PHP
php的一些小问题
Jul 03 PHP
使用XDebug调试及单元测试覆盖率分析
Jan 27 PHP
dedecms函数分享之获取某一栏目所有子栏目
May 19 PHP
Codeigniter实现智能裁剪图片的方法
Jun 12 PHP
一个经典实用的PHP图像处理类分享
Nov 18 PHP
php中array_column函数简单实现方法
Jul 11 PHP
Yii2框架实现注册和登录教程
Sep 30 PHP
thinkPHP内置字符串截取函数用法详解
Nov 15 PHP
PHP实现微信商户支付企业付款到零钱功能
Sep 30 PHP
PHP文件操作实例总结【文件上传、下载、分页】
Dec 08 PHP
Yii2.0框架模型多表关联查询示例
Jul 18 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
DedeCMS 核心类TypeLink.class.php摘要笔记
2010/04/07 PHP
php 数组动态添加实现代码(最土团购系统的价格排序)
2011/12/30 PHP
PHP cdata 处理(详细介绍)
2013/07/05 PHP
php通过array_shift()函数移除数组第一个元素的方法
2015/03/18 PHP
一个js写的日历(代码部分网摘)
2009/09/20 Javascript
JavaScript 在网页上单击鼠标的地方显示层及关闭层
2012/12/30 Javascript
JQuery给元素添加/删除节点比如select
2013/04/02 Javascript
Javascript仿PHP $_GET获取URL中的参数
2014/05/12 Javascript
jQuery中:first选择器用法实例
2014/12/30 Javascript
JS中字符串trim()使用示例
2015/05/26 Javascript
JavaScript获取并更改input标签name属性的方法
2015/07/02 Javascript
跟我学习javascript的Date对象
2015/11/19 Javascript
jQuery实现TAB选项卡切换特效简单演示
2016/03/04 Javascript
Bootstrap被封装的弹层
2016/07/20 Javascript
深入理解requestAnimationFrame的动画循环
2016/09/20 Javascript
JavaScript中Math对象的方法介绍
2017/01/05 Javascript
jQuery时间验证和转换为标准格式的时间格式
2017/03/06 Javascript
Node.js连接mongodb实例代码
2017/06/06 Javascript
Javascript将图片的绝对路径转换为base64编码的方法
2018/01/11 Javascript
JS+H5 Canvas实现时钟效果
2018/07/20 Javascript
Vue2(三)实现子菜单展开收缩,带动画效果实现方法
2019/04/28 Javascript
nuxt框架中对vuex进行模块化设置的实现方法
2019/09/06 Javascript
解决vue-router 二级导航默认选中某一选项的问题
2019/11/01 Javascript
浅谈vue使用axios的回调函数中this不指向vue实例,为undefined
2020/09/21 Javascript
[02:01]BBC DOTA2国际邀请赛每日综述:八强胜者组鏖战,中国队喜忧参半
2014/07/19 DOTA
python实现在pickling的时候压缩的方法
2014/09/25 Python
Python实现简单的获取图片爬虫功能示例
2017/07/12 Python
pandas去重复行并分类汇总的实现方法
2019/01/29 Python
Python Numpy库常见用法入门教程
2020/01/16 Python
5 分钟读懂Python 中的 Hook 钩子函数
2020/12/09 Python
市场专员岗位职责
2014/02/14 职场文书
2014年单位植树节活动方案
2014/03/23 职场文书
2014年监理个人工作总结
2014/12/11 职场文书
本科毕业论文指导教师评语
2014/12/30 职场文书
教师个人自我评价
2015/03/04 职场文书
DjangoRestFramework 使用 simpleJWT 登陆认证完整记录
2021/06/22 Python