php下载excel乱码的解决方案:1。下载时不要输出任何非文件信息;2.以相同方式保存输出excel格式和后缀名称;3.使用“ob_clean()”函数清空缓冲区。
推荐:“PHP视频教程”
当编写代码并下载我用PHP上传的Excel时,会出现此错误:
如果你强行打开它,它会被弄脏。
搜索片刻,有两种解释:
1.在下载过程中,不要输出任何非文件信息,如回声日志信息。否则,下载的文件无法打开,表明格式错误或文件损坏。2.输出的excel格式必须与后缀名称一致,否则会提示格式错误或文件损坏。
所以我改变了我点击下载的A标签的位置,并检查了excel的后缀名称,但是它不起作用。
后来发现问题可能出在BOM头,因为在乱码文件的前面有三个字符“0xEF 0xBB 0xBF”。而PHP不识别物料清单标题。
BOM表头说明:在utf-8编码的文件中,BOM在文件的表头,占据三个字节,用来表示文件属于utf-8编码。它通常是一个隐藏的字符串。许多软件可以识别和忽略物料清单标题,而PHP不能。
因此,要上传的文件可以在通过editplus、ultraedit或WINHEX等软件删除物料清单标题后上传。如果已下载,请移除物料清单标题并再次打开。
此外,您还可以在readfile、fread或output之前添加代码:ob_clean()来清除缓冲区。以上是如何解决php下载excel的乱码问题的细节