Bo-Blog UTF-8 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。)不过有时候不会显示。

Bo-Blog使用手册导航

Bo-Blog安装

Bo-Blog安装环境 | Bo-Blog文件目录结构 | Bo-Blog详细安装

Bo-Blog模板

模板的设计与制作 | 模板的安装与移除

Bo-Blog插件

Bo-Blog插件 |插件安装卸载 | 插件模块的添加配置

Bo-Blog版本升级

升级注意事项 | Bo-Blog2.0.3过渡到2.1.0

Bo-Blog数据

数据库备份 | 常用SQL语句

Bo-BlogFAQ

使用注意事项 | 安装常见问题 | 日常使用解答 | URL的优化问答 | UTF-8 BOM的问题

Bo-BlogF其他

关于OpenID | 关于Robots