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文件发给客户就问题解决啦!
并且叮嘱客户不要用记事本去打开这些文件!!!