博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
PHPExcel在Windows下出错 修复方案
阅读量:6091 次
发布时间:2019-06-20

本文共 1792 字,大约阅读时间需要 5 分钟。

环境

  • XAMPP 7.0.9 (PHP 7.0.9)
  • not
  • Windows 10.1
  • thinkPHP 5.0.1

Steps

  1. 安装好PHPExcel,可以使用composer安装;

  2. 第一个错误是phpzip库没有找到,ZipArchive and lib-zip.dll

    PHPExcel 依赖 lib_zip库,需要在PHP的php.conf文件中打开。PHP5.3+默认有这个库,但是XAMPP TMD居然没有。要看有没有可以打开 XAMPP_ROOT/php/ext/ (in Windows) 文件夹看有没有 lib_zip.dll
    如果没有可以从 下载,拖到 lib_zip.dll 上面的文件夹中。but,好像不行,需要重新编译PHP。

  3. PHPExcel内置的zip库 PCLZIP

    phpexcel 有一个 Pclzip 类,作为 lib_zip 缺失的情况下的备胎,具体可以看( from )
    需要在加载IOFactory方法前 添加一句PHPExcel_Settings::setZipClass(PHPExcel_Settings::PCLZIP);来切换到内置的zip库。

  4. 路径有问题 Classes/Shared/ZipArchive.php

    但是内置的 Classes/Shared/ZipArchive.php 类有个不兼容Windows路径的错误需要更正一下,在方法 public function getFromName($fileName)(141行)。
    找到的错误是传进来的 $fileName 包含的路径是这样的の xl/_rels/workbook.xml.rels(即使在windows下也是斜线模式,*nix)但是实际在 $list 数组中的却是Windows的反斜线风格 xl\_rels\workbook.xml.rels,斜线和反斜线不匹配,So 问题来了。
    需要在匹配的if判断中添加反斜线的匹配!!!!!!!!!!!!!

# beforeif (strtolower($list[$i]["filename"]) == strtolower($fileName) || strtolower($list[$i]["stored_filename"]) == strtolower($fileName)) {# afterif (strtolower($list[$i]["filename"]) == strtolower($fileName) || str_replace("/", "\u{5c}", strtolower($fileName)) == strtolower($list[$i]["filename"]) || strtolower($list[$i]["stored_filename"]) == strtolower($fileName) || str_replace("/", "\u{5c}", strtolower($fileName)) == strtolower($list[$i]["stored_filename"])) {# \u{5c} is backslash

还会有一个问题就是 "**Variable contents is not defined", so 再小改一下

# before        if ( is_array($extracted) && $extracted > 0 ) {            $contents = $extracted[0]["content"];        }    return $contents;#after        $contents = "";        if ( is_array($extracted) && $extracted > 0 ) {            $contents = $extracted[0]["content"];        return $contents;        }    return false;

现在可以在PHP7(Windows)中使用了

转载于:https://www.cnblogs.com/raybiolee/p/5956890.html

你可能感兴趣的文章
第三章 计算机及服务器硬件组成结合企业运维场景 总结
查看>>
IntelliJ IDEA解决Tomcal启动报错
查看>>
默认虚拟主机设置
查看>>
php中的短标签 太坑人了
查看>>
[译] 可维护的 ETL:使管道更容易支持和扩展的技巧
查看>>
### 继承 ###
查看>>
数组扩展方法之求和
查看>>
astah-professional-7_2_0安装
查看>>
函数是对象-有属性有方法
查看>>
uva 10107 - What is the Median?
查看>>
Linux下基本栈溢出攻击【转】
查看>>
c# 连等算式都在做什么
查看>>
使用c:forEach 控制5个换行
查看>>
java web轻量级开发面试教程摘录,java web面试技巧汇总,如何准备Spring MVC方面的面试...
查看>>
使用ansible工具部署ceph
查看>>
linux系列博文---->深入理解linux启动运行原理(一)
查看>>
Android反编译(一) 之反编译JAVA源码
查看>>
结合当前公司发展情况,技术团队情况,设计一个适合的技术团队绩效考核机制...
查看>>
python-45: opener 的使用
查看>>
cad图纸转换完成的pdf格式模糊应该如何操作?
查看>>