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 相关文章推荐
建立动态的WML站点(二)
Oct 09 PHP
php include的妙用,实现路径加密
Jul 29 PHP
php后退一页表单内容保存实现方法
Jun 17 PHP
解析crontab php自动运行的方法
Jun 24 PHP
PHP面向对象程序设计之接口用法
Aug 20 PHP
Laravel 4 初级教程之安装及入门
Oct 30 PHP
php生成图片缩略图的方法
Apr 07 PHP
PHP使用Face++接口开发微信公众平台人脸识别系统的方法
Apr 17 PHP
解决nginx不支持thinkphp中pathinfo的问题
Jul 21 PHP
PHP执行linux命令常用函数汇总
Feb 02 PHP
thinkPHP模板引擎用法示例
Dec 08 PHP
利用Homestead快速运行一个Laravel项目的方法详解
Nov 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开启gzip页面压缩实例代码
2010/03/11 PHP
php下载文件源代码(强制任意文件格式下载)
2014/05/09 PHP
javascript+php实现根据用户时区显示当地时间的方法
2015/03/11 PHP
浏览器图片选择预览、旋转、批量上传的JS代码实现
2013/12/04 Javascript
js实现简洁的TAB滑动门效果代码
2015/09/06 Javascript
jquery+json实现动态商品内容展示的方法
2016/01/14 Javascript
JavaScript事件详细讲解
2016/06/27 Javascript
全面了解addEventListener和on的区别
2016/07/14 Javascript
JS简单获取客户端IP地址的方法【调用搜狐接口】
2016/09/05 Javascript
jQuery实现文章图片弹出放大效果
2017/04/06 jQuery
react native带索引的城市列表组件的实例代码
2017/08/08 Javascript
JQuery元素快速查找与操作
2018/04/22 jQuery
javascript中call,apply,callee,caller用法实例分析
2019/07/24 Javascript
微信小程序自定义菜单切换栏tabbar组件代码实例
2019/12/30 Javascript
详解Webpack4多页应用打包方案
2020/07/16 Javascript
Flexible.js可伸缩布局实现方法详解
2020/11/13 Javascript
element 动态合并表格的步骤
2020/12/31 Javascript
python类继承用法实例分析
2014/10/10 Python
Python的批量远程管理和部署工具Fabric用法实例
2015/01/23 Python
python中偏函数partial用法实例分析
2015/07/08 Python
Python3学习笔记之列表方法示例详解
2017/10/06 Python
python中使用PIL制作并验证图片验证码
2018/03/15 Python
python中字符串数组逆序排列方法总结
2019/06/23 Python
Python编程快速上手——strip()函数的正则表达式实现方法分析
2020/02/29 Python
通过Python实现一个简单的html页面
2020/05/16 Python
AmazeUI 按钮交互的实现示例
2020/08/24 HTML / CSS
美国生鲜及杂货电商:FreshDirect
2018/01/29 全球购物
SCHIESSER荷兰官方网站:德国内衣专家
2020/10/09 全球购物
捐书寄语赠言
2014/01/18 职场文书
《再见了,亲人》教学反思
2014/02/26 职场文书
诚信考试承诺书
2014/03/27 职场文书
食品安全处置方案
2014/06/14 职场文书
谢师宴学生致辞
2015/07/27 职场文书
MySQL不使用order by实现排名的三种思路总结
2021/06/02 MySQL
mysql 子查询的使用
2022/04/28 MySQL
MySQL添加索引特点及优化问题
2022/07/23 MySQL