php 修复excel 乱码,php下载excel乱码的解决方法

当使用PHP下载Excel文件出现乱码时,可能的原因包括:在下载过程中输出了非文件信息、文件格式与后缀不一致,或者文件含有BOM头。解决方法包括清除缓冲区、确保文件格式正确以及使用编辑器去除BOM头。通过`ob_clean()`函数可以在输出文件前清空缓冲区,避免乱码问题。
摘要由CSDN通过智能技术生成

php下载excel乱码的解决方法

发布时间:2020-08-28 14:14:11

来源:亿速云

阅读:69

作者:小新

小编给大家分享一下php下载excel乱码的解决方法,希望大家阅读完这篇文章后大所收获,下面让我们一起去探讨吧!php下载excel乱码的解决办法:1、在下载的过程中取消任何非文件信息的输出;2、将输出的excel格式和后缀名保存一致;3、用“ob_clean”方法清空缓冲区。

737ec886aea89ecc1f55f71c58c2e3f9.png

编写代码,使用PHP下载一个我已经上传好的Excel时出现这个错误:

9dd0fa3a41c4ba8f3e6d0c25f624a3b2.png

强行打开则出现乱码。

搜索了一下,有两个解释:

1、在下载的过程中不要 输出任何非文件信息,比如 echo log信息。 否则下载后的文件无法打开,提示格式错误或者文件被破坏。

2、 输出的excel格式一定要和后缀名保存一致,否则会提示格式错误或者文件被破坏。

于是我更改了点击下载的a标签的位置,检查了excel后缀名,都没有作用。

后来搜索到可能是BOM头的问题,因为打开乱码的文件,前面都会有“0xEF 0xBB 0xBF”三个字符。而PHP无法识别BOM头。

BOM头的解释:在utf-8编码文件中BOM在文件头部,占用三个字节,用来标示该文件属于utf-8编码。它平时是一串隐藏的字符,许多软件可以识别并忽略BOM头,而PHP则不能。

因此,可以将需要上传的文件用editplus、ultraedit或者WINHEX等软件去掉BOM头之后,再上传。已经下载下来的则去掉BOM头再打开。

另外,也可以在你的readfile、fread,即输出前加上一句代码:ob_clean() 来清空缓冲区。

看完了这篇文章,相信你对php下载excel乱码的解决方法有了一定的了解,想了解更多相关知识,欢迎关注亿速云行业资讯频道,感谢各位的阅读!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值