首页 > Php > PHP的UTF-8 BOM引起的 Cannot send session cookie – headers already sent…

PHP的UTF-8 BOM引起的 Cannot send session cookie – headers already sent…

今天,在使用notepad++新制作一个程序时,总是提示警告,并且session不起作用。

Warning: session_start() [function.session-start]: Cannot send session cache limiter - headers already sent (output started at E:FukunPhpwap_cailingmodify.php:1) in E:fPhpwap_cailingchklogin.php on line 2

Warning: Cannot modify header information - headers already sent by (output started at E:fPhpwap_cailingmodify.php:1) in E:FukunPhpwap_cailingmodify.php on line 4

经检查后发现是由于PHP中的UTF-8格式的BOM引起的。
解决办法就是删除掉BOM,例如使用notepad++时,可以使用以下方式解决。

php中utf8编码的BOM引起的错误-Cannot send session cookie

php中utf8编码的BOM引起的错误-Cannot send session cookie

什么是 BOM?

简单来说,BOM是一种隐藏字符 ,类似WINDOWS自带的记事本等软件,在保存一个以UTF-8编码的文件时,会在文件开始的地方插入三个不可见的字符(0xEF 0xBB 0xBF,即BOM)。它是一串隐藏的字符,用于让记事本等编辑器识别这个文件是否以UTF-8编码。对于一般的文件,这样并不会产生什么麻烦。但对于 PHP来说,BOM是个大麻烦。

PHP并不会忽略BOM,所以在读取、包含或者引用这些文件时,会把BOM作为该文件开头正文的一部分。根据嵌入式语言的特点,这串字符将被直接执行(显示)出来。由此造成即使页面的 top padding 设置为0,也无法让整个网页紧贴浏览器顶部。

最大的麻烦还不是这个。受COOKIE送出机制的限制,在这些文件开头已经有BOM的文件中,COOKIE无法送出(因为在COOKIE送出前PHP已经送出了文件头),所以登入和登出功能失效。一切依赖COOKIE、SESSION实现的功能全部无效。

因此,在编辑、更改任何文本文件时,请务必使用不会乱加BOM的编辑器。Linux下的编辑器应该都没有这个问题。WINDOWS下,请勿使用记事本等编辑器。推荐的编辑器是: Editplus 2.12版本以上; EmEditor; UltraEdit(需要取消‘添加BOM’的相关选项); Dreamweaver(需要取消‘添加BOM’的相关选项)等。
对于已经添加了BOM的文件,要取消的话,可以用以上编辑器另存一次。(Editplus需要先另存为gb,再另存为UTF-8。)

  1. 还没有评论
评论提交中, 请稍候...

留言

可以使用的标签: <a href="" title=""> <abbr title=""> <acronym title=""> <b> <blockquote cite=""> <cite> <code> <del datetime=""> <em> <i> <q cite=""> <s> <strike> <strong>
Trackbacks & Pingbacks ( 0 )
  1. 还没有 trackbacks