隐藏字符 BOM

若是您在修改任何PHP文件後发生:
* 不能登入或者不能登出;
* 页顶出现一条空白;
* 页顶出现错误警告;
* 其它不正常的状况。
 
则多半是 编辑器的问题。
程序采用UTF-8编码。如今几乎全部的文本编辑软件均可以显示并编辑UTF-8编码的文件。可是很遗憾,其中不少软件的表现并不理想。
 
相似WINDOWS自带的 记事本等 软件,在保存一个以UTF-8编码的文件时,会在文件开始的地方插入三个不可见的字符(0xEF 0xBB 0xBF,即BOM)。它是一串隐藏的字符,用于让记事本等编辑器识别这个文件是否以UTF-8编码。对于通常的文件,这样并不会产生什么麻烦。但对于 PHP来讲,BOM是个大麻烦。
 
PHP并不会忽略BOM,因此在读取、包含或者引用这些文件时,会把BOM做为该文件开头正文的一部分。根据嵌入式 语言的特色,这串字符将被直接执行(显示)出来。由此形成即便页面的 top padding 设置为0,也没法让整个网页紧贴浏览器顶部,由于在html一开头有这3个字符呢!
 
最大的麻烦还不是这个。受COOKIE送出机制的限制,在这些文件开头已经有BOM的文件中,COOKIE没法送出(由于在COOKIE送出前PHP已经送出了文件头),因此登入和登出功能失效。一切依赖COOKIE、SESSION实现的功能所有无效。
 
所以,在编辑、更改任何文本文件时,请务必使用不会乱加BOM的编辑器。Linux下的编辑器应该都没有这个问题。 WINDOWS下,请勿使用记事本等编辑器。推荐的编辑器是: Editplus 2.12版本以上; EmEditor; UltraEdit(须要取消‘添加BOM’的相关选项); Dreamweaver(须要取消‘添加BOM’的相关选项)等。
 
对于已经添加了BOM的文件,要取消的话,能够用以上编辑器另存一次。(Editplus须要先另存为gb,再另存为UTF-8。)不过有时候不会显 。