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和ACCESS写聊天室(一)
Oct 09 PHP
PHP 动态随机生成验证码类代码
Apr 09 PHP
PHP字符过滤函数去除字符串最后一个逗号(rtrim)
Mar 26 PHP
fetchAll()与mysql_fetch_array()的区别详解
Jun 05 PHP
PHP判断远程图片是否存在的几种方法
May 04 PHP
PHP判断文章里是否有图片的简单方法
Jul 26 PHP
php中单个数据库字段多列显示(单字段分页、横向输出)
Jul 28 PHP
php cookie名使用点号(句号)会被转换
Oct 23 PHP
一张表搞清楚php is_null、empty、isset的区别
Jul 07 PHP
详解php中 === 的使用
Oct 24 PHP
浅谈PHP的反射机制
Dec 15 PHP
PHP实现生成推广海报的方法详解
Mar 14 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 FOR MYSQL 代码生成助手(根据Mysql里的字段自动生成类文件的)
2011/07/23 PHP
thinkPHP5.0框架开发规范简介
2017/03/25 PHP
Yii框架创建cronjob定时任务的方法分析
2017/05/23 PHP
PHP实现的一致性Hash算法详解【分布式算法】
2018/03/31 PHP
Laravel模型间关系设置分表的方法示例
2018/04/21 PHP
JavaScript中的类继承
2010/11/25 Javascript
node.js中的console.timeEnd方法使用说明
2014/12/09 Javascript
vue2利用Bus.js如何实现非父子组件通信详解
2017/08/25 Javascript
引入JavaScript时alert弹出框显示中文乱码问题
2017/09/16 Javascript
vue 中Virtual Dom被创建的方法
2019/04/15 Javascript
JavaScript实现美化滑块效果
2019/05/17 Javascript
了解JavaScript中let语句
2019/05/30 Javascript
JavaScript实现网页tab栏效果制作
2020/11/20 Javascript
[01:03:50]DOTA2-DPC中国联赛 正赛 CDEC vs DLG BO3 第二场 2月7日
2021/03/11 DOTA
Python列表推导式与生成器用法分析
2018/08/02 Python
Python实现的读取/更改/写入xml文件操作示例
2018/08/30 Python
python中的不可变数据类型与可变数据类型详解
2018/09/16 Python
python plotly画柱状图代码实例
2019/12/13 Python
Python 实现判断图片格式并转换,将转换的图像存到生成的文件夹中
2020/01/13 Python
使用Python防止SQL注入攻击的实现示例
2020/05/21 Python
HTML5 离线应用之打造零请求、无流量网站的解决方法
2013/04/25 HTML / CSS
浅谈基于HTML5的在线视频播放方案
2016/02/18 HTML / CSS
Sandro Paris美国官网:典雅别致的法国时尚服饰品牌
2017/12/26 全球购物
C#如何进行LDAP用户校验
2012/11/21 面试题
经贸日语专业个人求职信范文
2013/12/28 职场文书
幼儿园教师国培感言
2014/02/02 职场文书
网络工程专业自荐信范文
2014/03/16 职场文书
大学计划书范文800字
2014/08/14 职场文书
经典演讲稿开场白
2014/08/25 职场文书
八一建军节演讲稿
2014/09/10 职场文书
卡特教练观后感
2015/06/08 职场文书
2016年“抗战胜利纪念日”71周年校园广播稿
2015/12/18 职场文书
继续教育心得体会(共6篇)
2016/01/19 职场文书
终止合同协议书范本
2016/03/22 职场文书
彻底理解golang中什么是nil
2021/04/29 Golang
SQL Server使用T-SQL语句批处理
2022/05/20 SQL Server