使用php下载的文件打不开,自己用着没问题,客户用就不行?

Posted cation

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了使用php下载的文件打不开,自己用着没问题,客户用就不行?相关的知识,希望对你有一定的参考价值。

1 现象:

  开发的时候用的好好的文件下载功能,部署到客户那边就不好使了,几乎所有从服务器下载下来的文件都不能打开。

  比较了上传前的文件、上传后服务器端的文件、下载后本机的文件,发现同一个文件,上传后还好好的,通过php下载下来就多了3个字节。

  使用uediter用16进制模式打开文件发现文件头部多了“EF BB BF”这三个字节。

2 分析:

  上网很容易查到这三个字节叫bom头,windows用来标识这是个utf8格式的文件。

  一开始很容易想岔,比如在下载文件的时候删除这个bom头、比如强制windows在下载的时候不添加这个bom头,可惜以上方法是不可能实现的。

  最后看到某大神在某帖子里留言说,如果PHP文件自己带着一个bom头,那么通过这个PHP文件下载的文件就会自动被添加上bom头!

  于是我下载了服务器端的PHP文件,发现服务器端的PHP文件还真的多了这三个字节!而我本地的PHP文件没有!

  那这三个字节是哪里来的呢?

  因为客户在上传这个PHP文件前用记事本编辑了该文件!!!!!!

  因为我们使用编译器的时候,考虑到中文问题,一般会将PHP文件设置成utf-8格式,整个项目都是utf-8的。

  如果用记事本编辑了这个utf-8格式的文件,系统就会自动给它加上一个BOM头,备注这是个utf-8格式的文件,系统以后方便识别这个文件!!!

  终极原因还是因为PHP开发的时候就没考虑到中文问题,所以必须用utf-8格式,而操作系统为了方便自己就给文件前面加bom头!

  所以机缘巧合之下,看到这篇文章的你,也遇到这个问题啦。

3 解决办法:

  很简单,把没有用记事本编辑过的PHP文件发给客户就问题解决啦!

  并且叮嘱客户不要用记事本去打开这些文件!!!

以上是关于使用php下载的文件打不开,自己用着没问题,客户用就不行?的主要内容,如果未能解决你的问题,请参考以下文章

用PHPEXCEL生成文件时,为啥下载下来的excel文件打不开

我的安卓手机打不开exe的文件怎么办?

ArcGIS打不开,始终初始化应用程序?

火狐浏览器下载的文件为啥打不开

M3U8文件打不开,下载的ts文件也打不开,potplayer都打不开,求帮忙解决

我bt一直用的好好的,现在种子文件打不开,提示torrent文件解码错误,怎么回事?