今天弄php程序,突然发现一个问题,就是cookies无法保存,且不发生任何错误,经过一番查找发现问题如下:
因为程序在写cookies是用的是?@setcookie ( url, http://www.my400800.cn, time()+3600*24, /);
php 的 @、# 符号的意思
function foo($n)
{
? $result = 1/$n;
? return $result;
}
echo @foo(0); // 函数中会产生除 0 错误,但加上 @ 后并不显示该错误。
echo end; // 输出 end# 注释符号
同 // 一样,# 是单行注释符(多行注释符为 /* */)。
由于使用了@setcookie,即便在写入cookies是发生错误,也不会输出,造成了无法发现问题。最后把@setcookie改成 setcookie,程序输出如下错误信息:
warning: cannot modify header information - headers already sent by (output started at
经过上网一查,发现原来在进行setcookie设置前不能有任何输出内容,然后就去检查代码,也没有发现在setcookie之前输出了东西,在搜索了一下,发现了问题所在,具体内容如下:
?
今天在wordpress中文论坛逛了一圈。坛子里人气不高,不过还是有很多高手的。会编写插件和模版的高手和连编辑文件都不会的初学者混在一起,论坛就是这样,哈哈。
看到好几个帖子里提到同一个错误,比如这个帖子里提到的:warning: cannot modify header information - headers already sent by (output started at c:\program files\easyphp1-8\www\wp-config.php:1) in c:\program files\easyphp1-8\www\wp-login.php on line 9
这是一个很典型的问题。wordpress的程序执行时会首先调用wp-config.php一类的配置文件,也会调用wp-db.php建立数据库连接以备后用。这些文件只是做一些设置,并不输出html代码。设置完了后,程序本身开始执行了,有些程序会使用header命令设置一个http头。由于http头必须在html代码输出之前设置好,否则html代码已经开始往客户端发送了,http也就已经发送过了,没法追回来重新设置了。wordpress codex里对这个问题作出了说明:《how do i solve the headers already sent warning problem?》。文章指出:要确保各个文件――尤其是经常被编辑的wp-config.php文件――以结尾,前后不能有其他字符。具体到上面的例子,很明显,提示信息说wp-config.php的第一行就开始了html输出,这有可能是第一行的?
解决方法
wordpress中文论坛没有提供全文搜索的功能,只能搜索标题,所以我用google搜索了一下cannot modify header information site:wordpress.org.cn,好像碰到这个问题的人还真不少。目前大家用的wordpress主要是wordpress英文原版和几个wordpress中文版。我的中文包又不包含wp-config-sample.php文件,自然不关我的事;wordpress原版用的ascii码,自然不包含bom,也不会出这样的错误;xigang制作的wordpress中文版在wordpress中文论坛有下,我去下载了wordpress 2.0.4和2.0.3这两个,检查了一下,没有问题;点点游的wordpress 2.0.4中文版里,wp-config-sample.php文件用的是gb2312编码和dos行尾符,god!不过这样也好,如果有人用记事本修改了这个文件,dos行尾符不会造成编辑问题,gb2312编码不会造成bom的问题,呼。
唉,如果你要用wordpress架blog,还是扔掉记事本,装个ultraedit或者editplus吧!
?
?
